zoukankan      html  css  js  c++  java
  • (转)利用JDBC获取新插入记录id的三种方法

    本文转载自:http://blog.sina.com.cn/s/blog_5ce9f5040100fe57.html

    在一对多的关联操作中,通常在一方插入记录后,需要获取到当前记录的id,以方便进行多方的插入操作。要解决这一问题,在JDBC中至少有三种不同的实现方法:
    1.在插入语句后添加一条查询,利用resultset来得到id号
    psmt = con.prepareStatement
     

            ("insert into orders (receiver,address,telephone,total,detailnum,userid)values(?,?,?,?,?,?);select

    @@identity");
                psmt.setString(1, order.getReceiver());
                ……
                results = psmt.executeQuery();
                if(results.next())
                {
                    num = results.getInt(1);
                }
    2.利用generatedKey来获取id
    psmt = con.prepareStatement
                ("insert into orders (receiver,address,telephone,total,detailnum,userid)values

    (?,?,?,?,?,?)",Statement.RETURN_GENERATED_KEYS);
                psmt.setString(1, order.getReceiver());
                ……
                psmt.executeUpdate();
                results = psmt.getGeneratedKeys();
                int num = -1;
                if(results.next())
                {
                    num = results.getInt(1);
                }

    3.调用存储过程来实现,当然这种情况下,插入对象的属性不宜过多,否则存储过程的输入参数太多。在存储过程中,将id作为输出参数返回
    CallableStatement proc = conn.prepareCall("{call proc_insert(?,?,?)}");
                proc.setString(1, cardname);
                proc.setInt(2, money);
                proc.registerOutParameter(3, Types.INTEGER);
                proc.execute();
                num = proc.getInt(3)
  • 相关阅读:
    洛谷3703 [SDOI2017] 树点染色 【LCT】【线段树】
    BZOJ4818 [SDOI2017] 序列计数 【矩阵快速幂】
    HDU4625 JZPTREE 【树形DP】【第二类斯特林数】
    LOJ2116 [HNOI2015] 开店 【点分治】
    [NOIP2017] 逛公园 【最短路】【强连通分量】
    css
    html
    spring-springmvc-jdbc小案例
    eclipse myeclipse中的一些配置
    springmvc中的一些服务器报错
  • 原文地址:https://www.cnblogs.com/wpcnblog/p/2230689.html
Copyright © 2011-2022 走看看