tags: JDBC
1. A PreparedStatement object
PreparedStatement objects inherit from Statement objects, which are more powerful and simpler to use
- If the SQL Statement has variables, delimiters are used to separate them. If there are too many variables, the SQL Statement becomes very complex. Preparedstatements can use placeholders to simplify SQL writing
- Statements compile SQL frequently. PreparedStatement Allows SQL to be precompiled to improve efficiency. The prepared SQL is stored in the PreparedStatement object
- PreparedStatement prevents SQL injection. Statement (‘++’, ‘++’, ‘++’)
// simulate query for information with id 2
String id = "2";
Connection connection = UtilsDemo.getConnection();
String sql = "SELECT * FROM users WHERE id = ?";
PreparedStatement preparedStatement = connection.preparedStatement(sql);
// The first argument indicates the number of placeholders, and the second argument indicates the value
preparedStatement.setString(1,id);
ResultSet resultSet = preparedStatement.executeQuery();
if (resultSet.next()) {
System.out.println(resultSet.getString("name"));
}
// Release resources
UtilsDemo.release(connection, preparedStatement, resultSet);
Copy the code
2. The batch
When you need to send a batch of SQL statements to the database, do not send the SQL statements to the database one by one, and use batch processing to improve the execution efficiency
Batch processing can be done in two ways:
- Statement
- PreparedStatement
Execute SQL statements in batches using the executeBath() method, returning an array of int[] that represents the return value of each SQL statement
The following code implements batch processing as a Statement
/* * Statement execution batch processing * * Advantages: * Can send different SQL statements to the database * Disadvantages: * SQL is not precompiled * only SQL with different parameters, you need to write multiple SQL statements * */
Connection connection = UtilsDemo.getConnection();
Statement statement = connection.createStatement();
String sql1 = "UPDATE users SET name='zhongfucheng' WHERE id='3'";
String sql2 = "INSERT INTO users (id, name, password, email, birthday)" +
" VALUES('5','nihao','123','[email protected]','1995-12-1')";
// Add SQL to batch
statement.addBatch(sql1);
statement.addBatch(sql2);
// Perform batch processing
statement.executeBatch();
// Clear the batch SQL
statement.clearBatch();
UtilsDemo.release(connection, statement, null);
Copy the code
The following methods implement batch processing in PreparedStatement
/* * PreparedStatement Batch processing * Advantages: * SQL statements are precompiled * For the same type of SQL statements, you do not need to write many * disadvantages: * cannot send different types of SQL statements * * */
Connection connection = UtilsDemo.getConnection();
String sql = "INSERT INTO test(id,name) VALUES (? ,?) ";
PreparedStatement preparedStatement = connection.prepareStatement(sql);
for (int i = 1; i <= 205; i++) {
preparedStatement.setInt(1, i);
preparedStatement.setString(2, (i + "zhongfucheng"));
// Add to batch
preparedStatement.addBatch();
if (i %2= =100) {
// Perform batch processing
preparedStatement.executeBatch();
// If the data volume is too large, all the data stored in the batch, the memory will overflow.preparedStatement.clearBatch(); }}// Not all %2==100, the rest will be batch processed again
preparedStatement.executeBatch();
/ / empty again
preparedStatement.clearBatch();
UtilsDemo.release(connection, preparedStatement, null);
Copy the code
3. Processing large text and binary data
Clob or blob
- Clobs are used to store large text
- Blobs are used to store binary data
MYSQL
MySQL stores large text using Test (instead of CLOB), which is divided into four classes
- TINYTEXT
- TEXT
- MEDIUMTEXT
- LONGTEXT
Similarly, bloBs have these four categories
Use JDBC to connect to MySQL database to manipulate large text data and binary data
/ * * use JDBC to MySQL database operation big text data * * setCharacterStream (int parameterIndex, Java. IO. The Reader Reader, long length) * the second parameter is received a stream object, Because large text should not be received with String, String is too large to overflow memory * the third argument accepts the size of the file * * */
public class Demo5 {
@Test
public void add(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = JdbcUtils.getConnection();
String sql = "INSERT INTO test2 (bigTest) VALUES(?) ";
preparedStatement = connection.prepareStatement(sql);
// Get the path to the file
String path = Demo5.class.getClassLoader().getResource("BigTest").getPath();
File file = new File(path);
FileReader fileReader = new FileReader(file);
Mysql > select * from mysql. int; // Select * from mysql. int; The higher version does not require strong rotation
preparedStatement.setCharacterStream(1, fileReader, (int) file.length());
if (preparedStatement.executeUpdate() > 0) {
System.out.println("Insert successful"); }}catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(connection, preparedStatement, null); }}/* * To read large text data, obtain stream object data from getCharacterStream() in ResultSet * * */
@Test
public void read(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = JdbcUtils.getConnection();
String sql = "SELECT * FROM test2";
preparedStatement = connection.prepareStatement(sql);
resultSet = preparedStatement.executeQuery();
if (resultSet.next()) {
Reader reader = resultSet.getCharacterStream("bigTest");
FileWriter fileWriter = new FileWriter("d:\\abc.txt");
char[] chars = new char[1024];
int len = 0;
while((len = reader.read(chars)) ! = -1) {
fileWriter.write(chars, 0, len); fileWriter.flush(); } fileWriter.close(); reader.close(); }}catch (SQLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally{ JdbcUtils.release(connection, preparedStatement, resultSet); }}Copy the code
/* * Use JDBC to connect to MYsql database to manipulate binary data * If we want to store a large video in the database, the database cannot store it. * Max_allowed_packet needs to be set, generally we do not use the database to store a video * */
public class Demo6 {
@Test
public void add(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = JdbcUtils.getConnection();
String sql = "INSERT INTO test3 (blobtest) VALUES(?) ";
preparedStatement = connection.prepareStatement(sql);
// Get the file path and the file object
String path = Demo6.class.getClassLoader().getResource("1.wmv").getPath();
File file = new File(path);
// Call the method
preparedStatement.setBinaryStream(1.new FileInputStream(path), (int)file.length());
if (preparedStatement.executeUpdate() > 0) {
System.out.println("Added successfully"); }}catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(connection, preparedStatement, null); }}@Test
public void read(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = JdbcUtils.getConnection();
String sql = "SELECT * FROM test3";
preparedStatement = connection.prepareStatement(sql);
resultSet = preparedStatement.executeQuery();
// If data is read, write the data to disk
if (resultSet.next()) {
InputStream inputStream = resultSet.getBinaryStream("blobtest");
FileOutputStream fileOutputStream = new FileOutputStream("d:\\aa.jpg");
int len = 0;
byte[] bytes = new byte[1024];
while ((len = inputStream.read(bytes)) > 0) {
fileOutputStream.write(bytes, 0, len); } fileOutputStream.close(); inputStream.close(); }}catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(connection, preparedStatement, null); }}Copy the code
Oracle
The following uses JDBC to connect to Oracle database to manipulate large text data and binary data
// Use JDBC to connect to Oracle database to manipulate binary data
/* * There is a difference between Oracle and Mysql databases. * 1.Oracle defines a BLOB field, but this field does not actually store binary data * 2. Store a BLOB pointer to this field, retrieve the Oracle BLOB object, and place the binary data in the pointer to the BLOB field * 3. Transaction support is required * * */
public class Demo7 {
@Test
public void add(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = UtilsDemo.getConnection();
// Start the transaction
connection.setAutoCommit(false);
// Insert a BLOB pointer
String sql = "insert into test4(id,image) values(? ,empty_blob())";
preparedStatement = connection.prepareStatement(sql);
preparedStatement.setInt(1.1);
preparedStatement.executeUpdate();
// Query the BLOB pointer to the BLOB object
String sql2 = "select image from test4 where id= ? for update";
preparedStatement = connection.prepareStatement(sql2);
preparedStatement.setInt(1.1);
resultSet = preparedStatement.executeQuery();
if (resultSet.next()) {
// get the Blob object as Oracle Blob, not JDBC Blob.
BLOB blob = (BLOB) resultSet.getBlob("image");
// Write binary data
OutputStream outputStream = blob.getBinaryOutputStream();
// Get the read file read stream
InputStream inputStream = Demo7.class.getClassLoader().getResourceAsStream("01.jpg");
int len=0;
byte[] bytes = new byte[1024];
while ((len = inputStream.read(bytes)) > 0) {
outputStream.write(bytes, 0, len);
}
outputStream.close();
inputStream.close();
connection.setAutoCommit(true); }}catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
UtilsDemo.release(connection, preparedStatement, null); }}@Test
public void find(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = UtilsDemo.getConnection();
String sql = "SELECT * FROM test4 WHERE id=1";
preparedStatement = connection.prepareStatement(sql);
resultSet = preparedStatement.executeQuery();
if (resultSet.next()) {
// Get the BLOB object
BLOB blob = (BLOB) resultSet.getBlob("image");
// Read data to disk
InputStream inputStream = blob.getBinaryStream();
FileOutputStream fileOutputStream = new FileOutputStream("d:\\zhongfucheng.jpg");
int len=0;
byte[] bytes = new byte[1024];
while ((len = inputStream.read(bytes)) > 0) {
fileOutputStream.write(bytes, 0, len); } inputStream.close(); fileOutputStream.close(); }}catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
UtilsDemo.release(connection, preparedStatement, null); }}}Copy the code
I won’t repeat the CLOB data operation for JDBC connection to Oracle database, which is almost the same as BLOB
4. Obtain the automatic primary key column of the database
Why get automatic primary key column data for the database?
Application Scenarios:
There’s a list of teachers and a list of students. Now there is a new teacher and the students have to follow the new teacher.
I first need to know the id number of the teacher, so that students can know which teacher to follow.
@Test
public void test(a) {
Connection connection = null;
PreparedStatement preparedStatement = null;
ResultSet resultSet = null;
try {
connection = JdbcUtils.getConnection();
String sql = "INSERT INTO test(name) VALUES(?) ";
preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1."ouzicheng");
if (preparedStatement.executeUpdate() > 0) {
// Get the value of the automatic primary key column
resultSet = preparedStatement.getGeneratedKeys();
if (resultSet.next()) {
int id = resultSet.getInt(1); System.out.println(id); }}}catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtils.release(connection, preparedStatement, null);
}
Copy the code
5. Invoke the stored procedure of the database
Syntax for calling stored procedures:
{call <procedure-name>[(<arg1>,<arg2>, ...)] }Copy the code
Syntax for calling a function:
{? = call <procedure-name>[(<arg1>,<arg2>, ...)] }Copy the code
If it is Output, it will be registered at JDBC call time. The following code looks like this:
/* JDBC call stored procedure delimiter? CREATE PROCEDURE demoSp(IN inputParam VARCHAR(255), INOUT inOutParam varchar(255)) BEGIN SELECT CONCAT('zyxw---', inputParam) into inOutParam; END ? delimiter ; * /
// We call stored procedures in JDBC just as we call methods
public class Demo9 {
public static void main(String[] args) {
Connection connection = null;
CallableStatement callableStatement = null;
try {
connection = JdbcUtils.getConnection();
callableStatement = connection.prepareCall("{call demoSp(? ,?) }");
callableStatement.setString(1."nihaoa");
// Register the second parameter, of type VARCHAR
callableStatement.registerOutParameter(2, Types.VARCHAR);
callableStatement.execute();
// Get outgoing parameter [get stored procedure value]
String result = callableStatement.getString(2);
System.out.println(result);
} catch (Exception e) {
e.printStackTrace();
}finally {
try {
connection.close();
callableStatement.close();
} catch(SQLException e) { e.printStackTrace(); }}}Copy the code
References:
-- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- process # modify mysql statement is the result of the operator / / mysql > delimiter SQL > select * from users; Create procedure simpleproc(out count int) begin SELECT count(ID) into count from users; End // # alter mysql; mysql > delimiter ; Call simpleProc (@a); Select @a; String SQL = "{call simpleproc(?) } "; Connection conn = JdbcUtil.getConnection(); CallableStatement cstmt = conn.prepareCall(sql); cstmt.registerOutParameter(1,Types.INTEGER); cstmt.execute(); Integer count = cstmt.getInt(1); System.out.println(" count "+" count "); -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- function # modify mysql statement is the result of the operator for / / mysql > delimiter Create function hello(s char(20)) returns char(50) return concat('hello,',s,'! '); Mysql > alter table mysql > alter table mysql > alter table mysql mysql > delimiter ; Select hello('world'); String SQL = "{? = call hello(?) } "; Connection conn = JdbcUtil.getConnection(); CallableStatement cstmt = conn.prepareCall(sql); cstmt.registerOutParameter(1,Types.VARCHAR); cstmt.setString(2,"zhaojun"); cstmt.execute(); String value = cstmt.getString(1); System.out.println(value); JdbcUtil.close(cstmt); JdbcUtil.close(conn);Copy the code
If you find this article helpful, give the author a little encouragement