Объект PreparedStatement имеет возможность использовать входные и выходные потоки для предоставления данных параметров. Это позволяет помещать целые файлы в столбцы базы данных, которые могут содержать большие значения, такие как типы данных CLOB и BLOB.
Существуют следующие методы, которые можно использовать для потоковой передачи данных:
-
setAsciiStream (): Этот метод используется для предоставления больших значений ASCII.
-
setCharacterStream (): этот метод используется для предоставления больших значений UNICODE.
-
setBinaryStream (): этот метод используется для предоставления больших двоичных значений.
setAsciiStream (): Этот метод используется для предоставления больших значений ASCII.
setCharacterStream (): этот метод используется для предоставления больших значений UNICODE.
setBinaryStream (): этот метод используется для предоставления больших двоичных значений.
Метод setXXXStream () требует наличия дополнительного параметра, размера файла, помимо параметра-заполнителя. Этот параметр сообщает драйверу, сколько данных должно быть отправлено в базу данных с использованием потока.
пример
Предположим, мы хотим загрузить XML-файл XML_Data.xml в таблицу базы данных. Вот содержимое этого файла XML —
<?xml version="1.0"?> <Employee> <id>100</id> <first>Zara</first> <last>Ali</last> <Salary>10000</Salary> <Dob>18-08-1978</Dob> <Employee>
Храните этот XML-файл в том же каталоге, где вы собираетесь запустить этот пример.
В этом примере будет создана таблица базы данных XML_Data, а затем файл XML_Data.xml будет загружен в эту таблицу.
Скопируйте и вставьте следующий пример в JDBCExample.java, скомпилируйте и запустите следующим образом:
// Import required packages import java.sql.*; import java.io.*; import java.util.*; public class JDBCExample { // JDBC driver name and database URL static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost/EMP"; // Database credentials static final String USER = "username"; static final String PASS = "password"; public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt = null; Statement stmt = null; ResultSet rs = null; try{ // Register JDBC driver Class.forName("com.mysql.jdbc.Driver"); // Open a connection System.out.println("Connecting to database..."); conn = DriverManager.getConnection(DB_URL,USER,PASS); //Create a Statement object and build table stmt = conn.createStatement(); createXMLTable(stmt); //Open a FileInputStream File f = new File("XML_Data.xml"); long fileLength = f.length(); FileInputStream fis = new FileInputStream(f); //Create PreparedStatement and stream data String SQL = "INSERT INTO XML_Data VALUES (?,?)"; pstmt = conn.prepareStatement(SQL); pstmt.setInt(1,100); pstmt.setAsciiStream(2,fis,(int)fileLength); pstmt.execute(); //Close input stream fis.close(); // Do a query to get the row SQL = "SELECT Data FROM XML_Data WHERE id=100"; rs = stmt.executeQuery (SQL); // 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(); stmt.close(); pstmt.close(); conn.close(); }catch(SQLException se){ //Handle errors for JDBC se.printStackTrace(); }catch(Exception e){ //Handle errors for Class.forName e.printStackTrace(); }finally{ //finally block used to close resources try{ if(stmt!=null) stmt.close(); }catch(SQLException se2){ }// nothing we can do try{ if(pstmt!=null) pstmt.close(); }catch(SQLException se2){ }// nothing we can do try{ if(conn!=null) conn.close(); }catch(SQLException se){ se.printStackTrace(); }//end finally try }//end try System.out.println("Goodbye!"); }//end main public static void createXMLTable(Statement stmt) throws SQLException{ System.out.println("Creating XML_Data table..." ); //Create SQL Statement String streamingDataSql = "CREATE TABLE XML_Data " + "(id INTEGER, Data LONG)"; //Drop table first if it exists. try{ stmt.executeUpdate("DROP TABLE XML_Data"); }catch(SQLException se){ }// do nothing //Build table. stmt.executeUpdate(streamingDataSql); }//end createXMLTable }//end JDBCExample
Теперь давайте скомпилируем приведенный выше пример следующим образом:
C:\>javac JDBCExample.java C:\>
Когда вы запускаете JDBCExample , он дает следующий результат —