您如何确定使用Java和MySQL插入或更新是否成功?

问题描述

由于您正在使用PreparedStatement,因此可以致电@H_502_1@executeUpdate()-

  1. @H_502_1@ int count = stmt.executeUpdate();
  2. action = (count > 0); // <-- something like this.

通过上面的Javadoc( Return链接添加了重点,

(1) sql数据操作语言 (DML)语句 的 ,_或者(2)0不返回任何内容sql语句 _的 _ _ 。

如果您要插入大量条目,我更喜欢addBatch()executeBatch()

解决方法

我正在使用Java连接到MySQL数据库。我正在尝试向数据库中插入或更新数据。

即使我很确定插入成功,它也会返回false。

根据“执行” API,返回值是“如果第一个结果是ResultSet对象,则为true;如果是更新计数或没有结果,则为false”。

如何确定插入或更新是否成功?

  1. public boolean insertSelections(String selection,String name){
  2. String sql ="INSERT INTO WORKREPORT VALUES (?,?,?)";
  3. boolean action = false;
  4. try {
  5. PreparedStatement stmt = conn.prepareStatement(sql);
  6. SimpleDateFormat dateFormat = new java.text.SimpleDateFormat("yyyy:MM:dd hh:mm:ss");
  7. String formatDate = dateFormat.format(new java.util.Date(System.currentTimeMillis()));
  8. java.util.Date mDate = dateFormat.parse(formatDate);
  9. java.sql.Timestamp timeStamp = new java.sql.Timestamp(System.currentTimeMillis());
  10. // Date time= new Date(mDate.getTime());
  11. stmt.setInt(1,Integer.parseInt(getNumberByName(name).trim()));
  12. stmt.setString(2,name);
  13. // stmt.setDate(3,time);
  14. stmt.setTimestamp(3,timeStamp);
  15. stmt.setString(4,selection);
  16. stmt.setString(5,"N/A");
  17. action = stmt.execute();
  18. } catch (SQLException e) {
  19. // TODO Auto-generated catch block
  20. e.printStackTrace();
  21. } catch (ParseException e) {
  22. // TODO Auto-generated catch block
  23. e.printStackTrace();
  24. }
  25. return action;
  26. }

猜你在找的技术问答相关文章

如何检查配对的蓝牙设备是打印机还是扫描仪(Android)
是否允许实体正文进行HTTP DELETE请求?
如何将ZipInputStream转换为InputStream?
java.util.logging Java 8中的变量
PowerMockito.doReturn返回null
Java中的RESTful调用
Swing / Java:如何正确使用getText和setText字符串
特殊字符和重音字符
Android Studio中的ndk.dir错误
错误“找不到主类”