Java Mysql Prepared Statement Return Generated Keys
- Java Mysql Prepared Statement Return Generated Keys For Sale
- Prepared Statement In Java
- Java Mysql Prepared Statement Return Generated Keys 2017
- Java Mysql Prepared Statement Return Generated Keys For Windows 10
- Java Preparedstatement Return Generated Keys
The PreparedStatement interface is a subinterface of Statement. It is used to execute parameterized query.
Let's see the example of parameterized query:
MySQL Connector/J 5.1 Developer Guide / JDBC Concepts / Retrieving AUTOINCREMENT Column Values through JDBC 6.4 Retrieving AUTOINCREMENT Column Values through JDBC Before version 3.0 of the JDBC API, there was no standard way of retrieving key values from databases that supported auto increment or identity columns. Import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class Main.
As you can see, we are passing parameter (?) for the values. Its value will be set by calling the setter methods of PreparedStatement.
Why use PreparedStatement?
Improves performance: The performance of the application will be faster if you use PreparedStatement interface because query is compiled only once.
Java Mysql Prepared Statement Return Generated Keys For Sale
How to get the instance of PreparedStatement?
The prepareStatement() method of Connection interface is used to return the object of PreparedStatement. Syntax:
Methods of PreparedStatement interface
The important methods of PreparedStatement interface are given below:
Method | Description |
---|---|
public void setInt(int paramIndex, int value) | sets the integer value to the given parameter index. |
public void setString(int paramIndex, String value) | sets the String value to the given parameter index. |
public void setFloat(int paramIndex, float value) | sets the float value to the given parameter index. |
public void setDouble(int paramIndex, double value) | sets the double value to the given parameter index. |
public int executeUpdate() | executes the query. It is used for create, drop, insert, update, delete etc. |
public ResultSet executeQuery() | executes the select query. It returns an instance of ResultSet. |
Example of PreparedStatement interface that inserts the record
First of all create table as given below:
Now insert records in this table by the code given below:
Example of PreparedStatement interface that updates the record
Example of PreparedStatement interface that deletes the record
Example of PreparedStatement interface that retrieve the records of a table
Example of PreparedStatement to insert records until user press n
Date: November 04, 2004 11:39AM
[java] at com.mysql.jdbc.Statement.getGeneratedKeys(Statement.java:308)
--- details below ---
MySql version: 4.0.21-nt
MySql JConnector Driver version: 3.0.15-ga
table:
create table dp_objtype
(
objtypeid int not null auto_increment,
objname varchar(64) not null,
objclass varchar(255) null,
PRIMARY KEY (objtypeid)
) type = innoDB;
statement:
PreparedStatement pstmt = conn.preparedStatement('insert into dp_objtype (objname, objclass) values (?,?)', Statement.RETURN_GENERATED_KEYS);
If I use pstmt.execute(), the insert-stmt executed without any problem. If I use pstmt.getGeneratedKeys(), I get the following Exception:
[java] psqlstmt = insert into dp_objtype (objname, objclass) values (?,?)
[java] set val[1] = user
[java] set val[2] = com.datapipes.db.User
[java] java.lang.NullPointerException
[java] at com.mysql.jdbc.Statement.getGeneratedKeys(Statement.java:308)
[java] at com.mysql.jdbc.PreparedStatement.getGeneratedKeys(PreparedSta
tement.java:538)
[java] at com.ace.db.DbHelper.insertObject(DbHelper.java:351)
If someone can tell me how to correct this, or if there is a fix for it somewhere.
thanks
-alex
Prepared Statement In Java
Java Mysql Prepared Statement Return Generated Keys 2017
Java Mysql Prepared Statement Return Generated Keys For Windows 10
Java Preparedstatement Return Generated Keys
Content reproduced on this site is the property of the respective copyright holders. It is not reviewed in advance by Oracle and does not necessarily represent the opinion of Oracle or any other party.