千家信息网

mysql中LAST_INSERT_ID()的作用是什么

发表于:2024-11-18 作者:千家信息网编辑
千家信息网最后更新 2024年11月18日,本篇文章为大家展示了mysql中LAST_INSERT_ID()的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。首先看mysql中的LAST_INS
千家信息网最后更新 2024年11月18日mysql中LAST_INSERT_ID()的作用是什么

本篇文章为大家展示了mysql中LAST_INSERT_ID()的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。



首先看mysql中的LAST_INSERT_ID()的官方说法:

LAST_INSERT_ID()自动返回最后一个INSERT或UPDATE查询中AUTO_INCREMENT列设置的第一个表发生的值。
MySQL的LAST_INSERT_ID的注意事项:

第一、查询和插入所使用的Connection对象必须是同一个才可以,否则返回值是不可预料的。
第二、LAST_INSERT_ID是与表无关的,如果向表a插入数据后再向表b插入数据,LAST_INSERT_ID返回表b的Id值。 www.2cto.com
第三、假如你使用一条INSERT语句插入多个行, LAST_INSERT_ID() 只返回插入的第一行数据时产生的值。
第四、假如你使用 INSERT IGNORE而记录被忽略,则AUTO_INCREMENT 计数器不会增量,而 LAST_INSERT_ID() 返回0, 这反映出没有插入任何记录。

根据这四条原则,我们讨论的高并发网站访问时的插入后取自增长值其实主要是跟第一条规则和第二条规则有关。即要保证LAST_INSERT_ID的正确性,必须同一个connection,并且LAST_INSERT_ID要紧跟在insert中执行。所以如果是缓存池公用connection可能会出问题,多线程操作在insert后面由执行了别的insert时也会出问题。

而php的数据库连接本身是页面级的,这样就保证了不会出现缓冲池的情况,然后php页面执行本身也是单线程的,这样就保证了顺序编写的LAST_INSERT_ID肯定是紧跟在insert之后执行的,中间不会有别的insert执行。 www.2cto.com

综上所述,php的页面级、单线程其实已经保证了的LAST_INSERT_ID天然就是正确的,跟高并发并没有关系。即php中,mysql的LAST_INSERT_ID总是正确的,随便用把,没有问题的。

上述内容就是mysql中LAST_INSERT_ID()的作用是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。

数据 保证 线程 问题 页面 作用 内容 就是 技能 知识 规则 查询 简明 简明扼要 一行 事项 原则 增量 增长值 多个 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 安全模式与网络安全模式区别 华测rtk数据库更新 中国网络安全法选择题 计算机网络技术的职业选择 服务器损坏还能不能玩绝地求生 网络安全红队是什么意思 工业园区电子网络技术哪个好 阿里云云服务器运行音乐 做会计的有做软件开发的工资高吗 未来家庭需要配备服务器吗 南京福嶝网络技术有限公司 饥荒联机如何搜索服务器 软件开发教师资质 诺亚之心有几个服务器 服务器安全策略远程打开 服务器装ftp是否安全 神武服务器55突70 怎么查浏览器使用代理服务器 临沂三盛网络技术有限公司 兴化什么是网络技术诚信合作 软件开发税 网络安全发运营者指 丽水制造软件开发是做什么的 关于组织网络安全知识技能竞赛 我的世界pe服务器游戏 江苏省网络安全实践案例 相册数据库 不履行网络安全义务违法 佳木斯租房软件开发 怎么在数据库恢复玩家的数据
0