免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 9221 | 回复: 6
打印 上一主题 下一主题

【已解决】在sql里获取第一条insert的id [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-08-08 11:54 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2013-08-13 14:29 编辑

insert into table1 (...) values (...);
-- 接着获取上一条insert_id
insert into table2 (table1_id,...) values ()

这个有没有可能实现,在sql脚本里面

论坛徽章:
0
2 [报告]
发表于 2013-08-08 12:16 |只看该作者
自己找个空库试一下呗

论坛徽章:
0
3 [报告]
发表于 2013-08-08 15:01 |只看该作者
虽然可以获取last_id,但是不建议这样做,因为操作频繁的情况这样的id肯定会不一致。
建议在应用里面根据算法生成一个id,然后insert到两个表里面。

论坛徽章:
8
CU大牛徽章
日期:2013-09-18 15:20:48CU大牛徽章
日期:2013-09-18 15:20:58CU大牛徽章
日期:2013-09-18 15:21:06CU大牛徽章
日期:2013-09-18 15:21:12CU大牛徽章
日期:2013-09-18 15:21:17天秤座
日期:2013-10-30 14:01:03摩羯座
日期:2013-11-29 18:02:31luobin
日期:2016-06-17 17:46:36
4 [报告]
发表于 2013-08-13 11:14 |只看该作者
@linguijiang
这种东西建议使用触发器做。

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
5 [报告]
发表于 2013-08-13 14:29 |只看该作者
last_insert_id();

@@identity;

这个数值在单个连接上保证一致性。一般client都是阻塞顺序的,不会有3楼说的情况。

论坛徽章:
0
6 [报告]
发表于 2013-08-13 16:47 |只看该作者
首先谢谢各位的好意了

我这样想是因为之前看到postgresql在insert后可以附带一个returning id的语法,我按找网上的方法试了一下postgresql:
  1. with rows as (
  2.     INSERT INTO useid (name) VALUES ('a_title') RETURNING id
  3. )
  4. INSERT INTO debuguseid (name)
  5. SELECT id
  6. FROM rows
复制代码
这个是可以的,但公司的网站用的是mysql,却又刚好碰上需要这么一个问题
回复 5# cenalulu


   

论坛徽章:
0
7 [报告]
发表于 2013-08-13 16:57 |只看该作者
如果可能在同时也有其他用户插入数据的话,last id会不会得到不准确的id
回复 5# cenalulu


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP