获取mysql表插入数据自增字段的值
2016-07-15 10:03
381 查看
1. select max(id) from tablename
但是在多用户操作时不能使用这种方法
2.SELECT LAST_INSERT_ID() 函数
LAST_INSERT_ID 是与table无关的,如果向表a插入数据后,再向表b插入数据,LAST_INSERT_ID会改变。
LAST_INSERT_ID是基于Connection的,只要每个线程都使用独立的 Connection对象,LAST_INSERT_ID函数将返回该Connection对AUTO_INCREMENT列最新的insert or update 操作生成的第一个record的ID。这个值不能被其它客户端(Connection)影响,保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁。使用单INSERT语句插入多条记录,
LAST_INSERT_ID返回一个列表。
3. select @@IDENTITY
@@identity 是表示的是最近一次向具有identity属性(即自增列)的表插入数据时对应的自增列的值,是系统定义的全局变量。一般系统定义的全局变量都是以@@开头,用户自定义变量以@开头。
例:INSERT INTO
t_grade (name, grade)
VALUES ( "哈哈",123); SELECT @@identity
在我测试的时候一直通不过,就是因为在insert语句后面少加了个
;
以后一定要注意,并且两表关联是同时插入数据时候还可以使用触发器和事务来完成,这个可以在以后做项目的时候运用,继续学习!!!
但是在多用户操作时不能使用这种方法
2.SELECT LAST_INSERT_ID() 函数
LAST_INSERT_ID 是与table无关的,如果向表a插入数据后,再向表b插入数据,LAST_INSERT_ID会改变。
LAST_INSERT_ID是基于Connection的,只要每个线程都使用独立的 Connection对象,LAST_INSERT_ID函数将返回该Connection对AUTO_INCREMENT列最新的insert or update 操作生成的第一个record的ID。这个值不能被其它客户端(Connection)影响,保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁。使用单INSERT语句插入多条记录,
LAST_INSERT_ID返回一个列表。
3. select @@IDENTITY
@@identity 是表示的是最近一次向具有identity属性(即自增列)的表插入数据时对应的自增列的值,是系统定义的全局变量。一般系统定义的全局变量都是以@@开头,用户自定义变量以@开头。
例:INSERT INTO
t_grade (name, grade)
VALUES ( "哈哈",123); SELECT @@identity
在我测试的时候一直通不过,就是因为在insert语句后面少加了个
;
以后一定要注意,并且两表关联是同时插入数据时候还可以使用触发器和事务来完成,这个可以在以后做项目的时候运用,继续学习!!!
相关文章推荐
- MySQL中的integer 数据类型
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- MySQL存储过程
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- mysql中int、bigint、smallint 和 tinyint的区别与长度
- mysql load data 导出、导入 csv
- source命令执行SQL脚本文件
- PropertyChangeListener简单理解
- JSP/PHP基于Ajax的分页功能实现