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

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。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何实现从tello无人机上获取视频流,然后将获取的视频通过yolov5进行检测
  • ¥15 WPF使用Canvas绘制矢量图问题
  • ¥15 用三极管设计一个单管共射放大电路
  • ¥15 孟德尔随机化r语言运行问题
  • ¥15 pyinstaller编译的时候出现No module named 'imp'
  • ¥15 nirs_kit中打码怎么看(打码文件是csv格式)
  • ¥15 怎么把多于硬盘空间放到根目录下
  • ¥15 Matlab问题解答有两个问题
  • ¥15 LCD12864中文显示
  • ¥15 在使用CH341SER.EXE时不小心把所有驱动文件删除了怎么解决