- Java & MySQL 教程
- Java & MySQL - 首頁
- Java & MySQL - 概述
- Java & MySQL - 環境設定
- Java & MySQL - 示例程式碼
- Java & MySQL - 連線
- Java & MySQL - 異常
- Java & MySQL 語句
- Java & MySQL - Statement
- Java & MySQL - PreparedStatement
- Java & MySQL - CallableStatement
- Java & MySQL 結果集
- Java & MySQL - ResultSet
- Java & MySQL - 遍歷結果集
- Java & MySQL - 檢視結果集
- Java & MySQL - 更新結果集
- Java & MySQL 事務
- Java & MySQL - 事務
- Java & MySQL - 提交 & 回滾
- Java & MySQL - SavePoint 事務
- Java & MySQL 批處理
- Java & MySQL - 批處理
- 批處理 - Statement
- 批處理 - 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:///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:\>
廣告