- Java 和 MySQL 教程
- Java 和 MySQL - 主页
- Java 和 MySQL - 概述
- Java 和 MySQL - 环境设置
- Java 和 MySQL - 示例代码
- Java 和 MySQL - 连接
- Java 和 MySQL - 异常
- Java 和 MySQL 语句
- Java 和 MySQL - 声明
- Java 和 MySQL - 准备语句
- Java 和 MySQL - CallableStatement
- Java 和 MySQL 结果
- Java 和 MySQL - 结果集
- Java 和 MySQL - 导航结果集
- Java 和 MySQL - 查看结果集
- Java 和 MySQL - 更新结果集
- Java 和 MySQL 事务
- Java 和 MySQL - 事务
- Java 和 MySQL - 提交和回滚
- Java 和 MySQL - SavePoint 事务
- Java 和 MySQL 批处理
- Java 和 MySQL - 批处理
- 批处理 - 语句
- 批处理-PreparedStatement
- Java 和 MySQL 流
- Java 和 MySQL - 流数据
- Java 和 MySQL 示例
- Java 和 MySQL - 创建数据库
- Java 和 MySQL - 选择数据库
- Java 和 MySQL - 删除数据库
- Java 和 MySQL - 创建表
- Java 和 MySQL - 删除表
- Java 和 MySQL - 插入记录
- Java 和 MySQL - 选择记录
- Java & MySQL - 更新记录
- Java 和 MySQL - 删除记录
- Java 和 MySQL -Where 子句
- Java 和 MySQL - Like 子句
- Java 和 MySQL - 数据排序
- Java 和 MySQL 有用资源
- Java 和 MySQL - 快速指南
- Java 和 MySQL - 有用的资源
- Java 和 MySQL - 讨论
Java 和 MySQL - 流数据
PreparedStatement 对象能够使用输入和输出流来提供参数数据。这使您能够将整个文件放入可以保存大值(例如 CLOB 和 BLOB 数据类型)的数据库列中。
有以下方法可用于流数据 -
setAsciiStream() - 此方法用于提供大的 ASCII 值。
setCharacterStream() - 此方法用于提供大的 UNICODE 值。
setBinaryStream() - 此方法用于提供大的二进制值。
除了参数占位符之外,setXXXStream() 方法还需要一个额外的参数,即文件大小。此参数通知驱动程序应使用流将多少数据发送到数据库。
此示例将创建一个数据库表 XML_Data,然后将 XML 内容写入该表中。
将以下示例复制并粘贴到 TestApplication.java 中,编译并运行如下 -
import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class TestApplication { static final String DB_URL = "jdbc:mysql://localhost/TUTORIALSPOINT"; static final String USER = "guest"; static final String PASS = "guest123"; static final String QUERY = "SELECT Data FROM XML_Data WHERE id=100"; static final String INSERT_QUERY="INSERT INTO XML_Data VALUES (?,?)"; static final String CREATE_TABLE_QUERY = "CREATE TABLE XML_Data (id INTEGER, Data LONG)"; static final String DROP_TABLE_QUERY = "DROP TABLE XML_Data"; static final String XML_DATA = "<Employee><id>100</id><first>Zara</first><last>Ali</last><Salary>10000</Salary><Dob>18-08-1978</Dob></Employee>"; public static void createXMLTable(Statement stmt) throws SQLException{ System.out.println("Creating XML_Data table..." ); //Drop table first if it exists. try{ stmt.executeUpdate(DROP_TABLE_QUERY); }catch(SQLException se){ } stmt.executeUpdate(CREATE_TABLE_QUERY); } public static void main(String[] args) { // Open a connection try(Connection conn = DriverManager.getConnection(DB_URL, USER, PASS); Statement stmt = conn.createStatement(); PreparedStatement pstmt = conn.prepareStatement(INSERT_QUERY); ) { createXMLTable(stmt); ByteArrayInputStream bis = new ByteArrayInputStream(XML_DATA.getBytes()); pstmt.setInt(1,100); pstmt.setAsciiStream(2,bis,XML_DATA.getBytes().length); pstmt.execute(); //Close input stream bis.close(); ResultSet rs = stmt.executeQuery(QUERY); // Get the first row if (rs.next ()){ //Retrieve data from input stream InputStream xmlInputStream = rs.getAsciiStream (1); int c; ByteArrayOutputStream bos = new ByteArrayOutputStream(); while (( c = xmlInputStream.read ()) != -1) bos.write(c); //Print results System.out.println(bos.toString()); } // Clean-up environment rs.close(); } catch (SQLException | IOException e) { e.printStackTrace(); } } }
现在让我们按如下方式编译上面的示例 -
C:\>javac TestApplication.java C:\>
当您运行TestApplication时,它会产生以下结果 -
C:\>java TestApplication Creating XML_Data table... <Employee><id>100</id><first>Zara</first><last>Ali</last><Salary>10000</Salary><Dob>18-08-1978</Dob></Employee> C:\>