executeUpdate()方法的使用
PreparedStatement pre = con.prepareStatement(sql);
pre.executeUpdate();
............
............
// 可以看到既没有整形数据来接收executeUpdate()的返回值,又没有给executeUpdate()传实参;
这到底怎么理解啊? 展开
方法executeUpdate
用于执行INSERT、UPDATE或DELETE语句以及SQLDDL(数据定义语言)语句,例如CREATETABLE和DROPTABLE。INSERT、UPDATE或DELETE语句的效果是修改表中零行或多行中的一列或多列。
executeUpdate的返回值是一个整数,指示受影响的行数(即更新计数)。对于CREATETABLE或DROPTABLE等不操作行的语句,executeUpdate的返回值总为零。
使用executeUpdate方法是因为在createTableCoffees中的SQL语句是DDL(数据定义语言)语句。创建表,改变表,删除表都是DDL语句的例子,要用executeUpdate方法来执行。也可以从它的名字里看出,方法executeUpdate也被用于执行更新表SQL语句。
扩展资料:
方法execute:
用于执行返回多个结果集、多个更新计数或二者组合的语句。因为多数程序员不会需要该高级功能
execute方法应该仅在语句能返回多个ResultSet对象、多个更新计数或ResultSet对象与更新计数的组合时使用。当执行某个已存储过程或动态执行未知SQL字符串(即应用程序程序员在编译时未知)时,有可能出现多个结果的情况,尽管这种情况很少见。
因为方法execute处理非常规情况,所以获取其结果需要一些特殊处理并不足为怪。
例如,假定已知某个过程返回两个结果集,则在使用方法execute执行该过程后,必须调用方法getResultSet获得第一个结果集,然后调用适当的getXXX方法获取其中的值。要获得第二个结果集,需要先调用getMoreResults方法,然后再调用getResultSet方法。
如果已知某个过程返回两个更新计数,则首先调用方法getUpdateCount,然后调用getMoreResults,并再次调用getUpdateCount。
对于不知道返回内容,如果结果是ResultSet对象,则方法execute返回true;如果结果是Javaint,则返回false。
如果返回int,则意味着结果是更新计数或执行的语句是DDL命令。在调用方法execute之后要做的第一件事情是调用getResultSet或getUpdateCount。
调用方法getResultSet可以获得两个或多个ResultSet对象中第一个对象;或调用方法getUpdateCount可以获得两个或多个更新计数中第一个更新计数的内容。
1、getResultSet
返回null意味着不是结果集可以理解为是一个更新计数或没有其它结果
2、getUpdateCount
返回影响的行数-1表示结果是结果集或没有结果
如果已经调用方法getResultSet并处理了它返回的ResultSet对象,则有必要调用方法getMoreResults以确定是否有其它结果集或更新计数。如果getMoreResults返回true,则需要再次调用getResultSet来检索下一个结果集。
如上所述,如果getResultSet返回null,则需要调用getUpdateCount来检查null是表示结果为更新计数还是表示没有其它结果。
当getMoreResults返回false时,它表示该SQL语句返回一个更新计数或没有其它结果。因此需要调用方法getUpdateCount来检查它是哪一种情况。在这种情况下,当下列条件为真时表示没有其它结果:
((stmt.getMoreResults()==false)&&(stmt.getUpdateCount()==-1))。
参考资料:
prepareStatement是statement的子接口自己定义了方法executeUpdate() 用于执行已发送的预编译的sql 并返回执行成功的记录的条数 int
一般都是用prepareStatement 有预编译功能可以防止sql注入攻击
你第二段 “prepareStatement是statement的子接口自己定义了方法executeUpdate() 用于执行已发送的预编译的sql 并返回执行成功的记录的条数 int
” 中预编译的sql 是什么意思?怎么理解? 另外 “并返回执行成功的记录的条数 int” 这么说也是有返回值的了,但是为什么在开发中有时候没有整形数据来接收返回值,而是像我在问题中写的那样,直接在调用?
预编译就是说在执行executeUpdate();时候,sql语句已经在数据库端了con.preparedStatement(sql) 就是发送sql了 当然了我个人是这样理解的
如果执行成功是有返回值得,但是这个返回值用处不大,比如我执行插入一行数据,返回值就是1,因为他成功的插入了一行数据,这个返回值你当然可以不接受,你可以接受一下并且打印出来看看是否如此
2018-12-26
增、删、改 用executeUpdate()
返回值为int型,表示被影响的行数
在这里插入图片描述