prepareStatement介绍与使用

来源:互联网 发布:mysql密码忘记了怎么办 编辑:程序博客网 时间:2024/06/06 18:19
      它表示预编译的SQL语句的对象,其中SQL语句被预编译并且存储在PreparedStatement对象中。然后可以使用此对象高效地多次执行该语句。
例子:
(1)PreparedStatement pstmt = con.prepareStatement("UPDATE EMPLOYEES SET SALARY = ? WHERE ID = ?");
(2)pstmt.setBigDecimal(1, 153833.00);        //将153833.00赋给第一个参数
(3)pstmt.setInt(2, 110592); //将110592赋给第二个参数
注释:
(1)setBigDecimal(int parameterIndex, BigDecimal x)将指定参数设置为给定BigDecimal类型的值。
(2)setInt(int parameterIndex, int x)将指定参数设置为给定int值。
(3)sql中的'?'为参数占位符,可以有多个。


(高级用法)
PreparedStatement prepareStatement(String sql,int resultSetType,int resultSetConcurrency) throws SQLException
此方法与上述prepareStatement方法相同,但它允许重写默认结果集类型和并发性。 
参数:
(1)String对象,它是将被发送到数据库的SQL语句可以包含一个或多个?IN参数
(2)resultSetType - 结果集类型,它是 ResultSet.TYPE_FORWARD_ONLY、ResultSet.TYPE_SCROLL_INSENSITIVE或ResultSet.TYPE_SCROLL_SENSITIVE 之一
(3)resultSetConcurrency - 并发类型,它是 ResultSet.CONCUR_READ_ONLY 或 ResultSet.CONCUR_UPDATABLE 之一 
返回:包含预编译的SQL语句的新PreparedStatement对象,该对象将生成具有给定类型和并发性的ResultSet对象
原创粉丝点击