如何解决从MySQL中的多插入获取LAST_INSERT_ID
在MySQL数据库中插入乘法行后,我需要获取id值
INSERT INTO table (`row1`,`row2`,`row3`,`row4`)
VALUES
('value1','value2','value3','value4'),('value1','value4');
事实上,我需要类似 SQL Server - Return value after INSERT 但是对于MySQL,我不需要返回最后一个id,因为我可以自己完成,但我认为这样做对我没有好处 有什么更好的方法可以解决我的问题吗?
解决方法
如果要在父表和子表中插入行块,则行必须具有唯一的列,以便在插入后可以查找父行:
INSERT INTO table (col1,col2,col3,col4)
VALUES
('value1','value2','value3','value4'),('value5','value6','value7','value8');
INSERT INTO childtable (colx,coly,id_table)
SELECT 1,2,id FROM table WHERE col1 = 'value1' and col2 = 'value2' and col3 = 'value3' and col4 = 'value4'
UNION ALL
SELECT 1,id FROM table WHERE col1 = 'value5' and col2 = 'value2' and col3 = 'value3' and col4 = 'value4'
即使有一种获取所有插入的ID的方法,您也必须做同样的事情,因为表包含一组无序的行。如果您获得了第一个插入语句的ID 11和12,ID 11将指向哪一行,ID 12将指向哪一行?由于DBMS可以自由地以任何顺序插入行,因此无法说明这一点。
如果行数据不是示例中唯一的,并且两行都包含(“ value1”,“ value2”,“ value3”,“ value4”),则必须将所有数据插入循环或使用一些CTE会先对行编号,然后使用这些编号进行播放。
无论如何,只要您不会遇到无法忍受的性能问题,我就将数据逐行插入循环中(例如,一个父级,所有子级,下一个父级...)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。