了解自增字段的值

Posted

技术标签:

【中文标题】了解自增字段的值【英文标题】:Knowing the value of autoincremented fields 【发布时间】:2014-12-03 12:02:31 【问题描述】:

使用代码在表中插入记录,其中一个字段是自动递增的 (id)。如何找出我刚刚插入的记录中的自动增量字段 (id) 的值是多少?

         PreparedStatement ps = null;
    Connection con = null;
    ResultSet rs = null;
    int rows = 0;
    try 
        String SQL_DRV = "org.hsqldb.jdbcDriver";
        String SQL_URL = "jdbc:hsqldb:hsql://localhost/localDB";

                    Class.forName(SQL_DRV);
        con = DriverManager.getConnection(SQL_URL, "sa", "");

                                ps = con.prepareStatement(
                "insert into infousuarios (nombre, apellidos, email) " +
                "values (?, ?, ?)");
        ps.setString(1, name);
        ps.setString(2, surnames);
        ps.setString(3, login+"@micorreo.com");


        rows = ps.executeUpdate();
        // How I can know the value of autoincrement field (id) of the record just enter??

【问题讨论】:

大多数数据库都有检索它的功能,通常是“last insert id”之类的。 看这个答案***.com/questions/10353405/… 已解决。谢谢@SemyonSadetsky 【参考方案1】:

使用getGeneratedKeys()

ps = con.prepareStatement(
      "insert into infousuarios (nombre, apellidos, email) " +
      "values (?, ?, ?)", Statement.RETURN_GENERATED_KEYS); 

ps.setString(1, name);
ps.setString(2, surnames);
ps.setString(3, login+"@micorreo.com");

rows = ps.executeUpdate();

ResultSet keys = ps.getGeneratedKeys();
long id = -1;

if (keys.next()) 
  id = rs.getLong(1);

注意对prepareStatement 的调用传递PreparedStatement.RETURN_GENERATED_KEYS 和对ps.getGeneratedKeys() 的调用

【讨论】:

【参考方案2】:

insert_id 可以检索最后插入的 id $id=$mysqli->insert_id;

【讨论】:

以上是关于了解自增字段的值的主要内容,如果未能解决你的问题,请参考以下文章

了解自增字段的值

sql server建表时怎么设置ID字段自增

外键以及数据库的增删改查你了解多少

delphi+ado+sqlserver怎样在插入之后返回自增字段的值?

JavaScript自增和自减

C#操作MongoDB实现自增列怎么写