JDBC - Streaming de données ASCII et binaires
Un objet PreparedStatement a la capacité d'utiliser des flux d'entrée et de sortie pour fournir des données de paramètres. Cela vous permet de placer des fichiers entiers dans des colonnes de base de données pouvant contenir des valeurs importantes, telles que les types de données CLOB et BLOB.
Il existe des méthodes suivantes, qui peuvent être utilisées pour diffuser des données -
setAsciiStream(): Cette méthode est utilisée pour fournir de grandes valeurs ASCII.
setCharacterStream(): Cette méthode est utilisée pour fournir de grandes valeurs UNICODE.
setBinaryStream(): Cette méthode est utilisée pour fournir de grandes valeurs binaires.
La méthode setXXXStream () nécessite un paramètre supplémentaire, la taille du fichier, en plus du paramètre fictif. Ce paramètre informe le pilote de la quantité de données à envoyer à la base de données à l'aide du flux.
Exemple
Considérez que nous voulons télécharger un fichier XML XML_Data.xml dans une table de base de données. Voici le contenu de ce fichier XML -
<?xml version="1.0"?>
<Employee>
<id>100</id>
<first>Zara</first>
<last>Ali</last>
<Salary>10000</Salary>
<Dob>18-08-1978</Dob>
<Employee>
Conservez ce fichier XML dans le même répertoire que celui où vous allez exécuter cet exemple.
Cet exemple créerait une table de base de données XML_Data, puis le fichier XML_Data.xml serait téléchargé dans cette table.
Copiez et collez l'exemple suivant dans JDBCExample.java, compilez et exécutez comme suit -
// 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
Maintenant, compilons l'exemple ci-dessus comme suit -
C:\>javac JDBCExample.java
C:\>
Quand tu cours JDBCExample, il produit le résultat suivant -
C:\>java JDBCExample
Connecting to database...
Creating XML_Data table...
<?xml version="1.0"?>
<Employee>
<id>100</id>
<first>Zara</first>
<last>Ali</last>
<Salary>10000</Salary>
<Dob>18-08-1978</Dob>
<Employee>
Goodbye!
C:\>