mysql自增id获取

mysql自增id获取

    • 使用max函数:select max(id) from tablename 
      • 优势:使用方便快捷。
      • 缺点:获取的不是真正的自增id,是表中最大的Id,若是有删除数据的话,那么该值和自增id相差比较大。若是有连表数据,有可能致使数据错乱。
    • 使用LAST_INSERT_ID函数:select LAST_INSERT_ID() 
      • 优势:获取到的是真正的自增id。
      • 缺点:该函数是与table无关的,永远保留最新插入的自增列的id。若是多客户端操做,并且不能保证原子性,这个值可能会出现错误。因此须要在插入以后调用。
    • 使用@@IDENTITY变量:select @@IDENTITY 
      • 此方法和LAST_INSERT_ID()功能差很少,优缺点也一致。须要在插入后调用。
    • 使用mysql查询函数:SHOW TABLE STATUS; 
      • 优势:可以准确的查到自增id。并且能够在语句后面加上where语句或者like语句来过滤。
      • 缺点:该语句返回的是一个记录集,不能单独的返回自增值。因此须要额外的操做来获取。
    • 使用自定义查询方法:mysql表相关的信息是放在information_schema表里。因此咱们参考 SHOW TABLE STATUS来构建查询语句。如: 
      • select Auto_increment into autoId from information_schema.tables where Table_Schema = ‘dbname’ and table_name = ‘tablename’;
      • 优势:高度自定义,可以准确的获得想获得的任何信息。
相关文章
相关标签/搜索