zoukankan      html  css  js  c++  java
  • JDBC通过getGeneratedKeys()获取主键的方法

    我们在插入某一条sql信息的同时,如果还需要获取对应的主键ID,就可以使用getGeneratedKeys()来获取主键ID

    代码如下:这里是明确知道只插入一条的情况

    public long insert(String sql, Object... args) {
        long id=0;
        Connection connection=null;
        PreparedStatement preparedStatement=null;
        ResultSet resultSet=null;
        try {
            connection=JDBCUtils.getConnection();
            preparedStatement=connection.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
            if(args!=null){
                for(int i=0;i<args.length;i++){
                    preparedStatement.setObject(i+1, args[i]);
                }
            }
            preparedStatement.executeUpdate();
            //获取生产的主键值
            resultSet=preparedStatement.getGeneratedKeys();//获取主键值
            
            if(resultSet.next()){
                id=resultSet.getLong(1);// getLong(1)是指获取第一列的值(一般第一列都为主键id)   所以id=它
            }
            System.out.println("产生的id"+id);
        } catch (Exception e) {
            // TODO: handle exception
        }finally{
            JDBCUtils.release(resultSet, preparedStatement);
            JDBCUtils.release(connection);
        }
            return id;
        }

    如果是批量插入,就要用while循环,if条件就不能实现批量插入,因为要获取多条数据对象对应的主键ID,所以用while得以实现,resultSet是一个数据集   .next获取它的下一个指针(可以理解成下一行数据) 

    代码如下

    public long insert(String sql, Object... args) {
        long id=0;
        Connection connection=null;
        PreparedStatement preparedStatement=null;
        ResultSet resultSet=null;
        try {
            connection=JDBCUtils.getConnection();
            preparedStatement=connection.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
            if(args!=null){
                for(int i=0;i<args.length;i++){
                    preparedStatement.setObject(i+1, args[i]);
                }
            }
            preparedStatement.executeUpdate();
            //获取生产的主键值
            resultSet=preparedStatement.getGeneratedKeys();//获取主键值
            
            while(resultSet.next()){
                id=resultSet.getLong(1);// getLong(1)是指获取第一列的值(一般第一列都为主键id)   所以id=它
            }
            System.out.println("产生的id"+id);
        } catch (Exception e) {
            // TODO: handle exception
        }finally{
            JDBCUtils.release(resultSet, preparedStatement);
            JDBCUtils.release(connection);
        }
            return id;
        }
  • 相关阅读:
    转《编程之美——微软技术面试心得》勘误表
    第一次 学习使用 智能指针
    test _todel
    (转 todo阅读)Android 官方博客 Android应用程序的内存分析(翻译)
    msdn snmp trap 研究可否 重入 转《Multiple Trap Registrations》
    wpbars在博客园开博客了
    创业失败的10个教训总结
    winform 的一种登录方法。
    快速建立Subversion
    (转)SQL Server 按某一字段分组取最大(小)值所在行的数据
  • 原文地址:https://www.cnblogs.com/wrkjwl/p/9237386.html
Copyright © 2011-2022 走看看