墨水有鱼
2019-11-07 00:05
采纳率: 40%
浏览 431
已采纳

JDBC添加数据在数据库中不显示,但是主键自动递增

在使用JDBC给数据增加数据的时候,返回值表面添加成功,但是在数据库中看不到,在数据库中使用sql直接运行可以添加,但是主键不连续(已经设置了主键自动递增)设置了主键自动递增,中间缺的差值正好是我在程序中运行的次数。

也就是说,sql成功传递到了数据库。但是不知道什么原因没有更新数据库,
数据库版本为mysql8.0(之前5.6版本的数据库也是同样的问题);
编译平台为idea2019.2.3;
数据库驱动为mysql-connector-java-8.0.18.jar。

String sql2 = "INSERT INTO user  VALUES ('8','klj','789456')";
insert(sql2);


public int insert(String sql) {
        int k = 0;
        try {
            PreparedStatement ps = conn.prepareStatement(sql);
//            ps.setString(1,"2");
//            ps.setString(2,"safasd");
//            ps.setString(3,"7896");
            System.out.println(ps);
            k = ps.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {//当数据库使用后必须关闭,如果没有关闭数据库的接口有限,下次就不能连接
            try {
                if (rs != null) {
                    rs.close();
//                    System.out.println("rs");
                }
            } catch (Exception e2) {
                e2.printStackTrace();
            }
            try {
                if (ps != null) {
                    ps.close();
//                    System.out.println("ps");
                }
            } catch (Exception e2) {
                e2.printStackTrace();
            }
            try {
                if (rs != null) {
                    rs.close();
//                    System.out.println("rs");
                }
            } catch (Exception e2) {
                e2.printStackTrace();
            }
        }
        return k;
    }
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • 毕小宝 2019-11-07 09:09
    已采纳

    JDBC 提交后刷新下数据库,再用 SQL 查询下看看有没有数据。
    或者代码中加一行 conn.commit() 提交一下 SQL。

    点赞 评论

相关推荐 更多相似问题