php - mysql,a、b是一对多,需要插入一条a记录和多条b记录,插入b表时,怎么拿a的id?需要事务保证成功
ringa_lee
ringa_lee 2017-04-10 17:47:50
[PHP讨论组]

a、b是一对多,需要插入一条a记录和多条b记录,需要开启事务。
$id = insert into a values(xx,xx);

foreach($b as $v)
{

将上面id赋值到每个数组$b

}
执行 insert into b values ($id,xx),($id,xx)

这样子做会影响效率吧?而且全部需要在事务里面进行。有其它什么办法吗

ringa_lee
ringa_lee

ringa_lee

全部回复(3)
ringa_lee

我不懂这样处理为什么会影响效率,就已知设定来看,你执行的逻辑是最优了。

阿神

下面的SQL是否OK,使用LAST_INSERT_ID()代替 $id

INSERT INTO a(xx,xx)
     VALUES ('xx','xx');
INSERT INTO b(xx, xx)
     VALUES 
     ('xx',LAST_INSERT_ID()),
     ('xx',LAST_INSERT_ID());
PHP中文网

以php 为例,插入 a 以后,获取 insert_id,下面的就好办了!!

`<?php

mysql_connect("localhost", "mysql_user", "mysql_password") or
    die("Could not connect: " . mysql_error());
mysql_select_db("mydb");

mysql_query("INSERT INTO mytable (product) values ('kossu')");
printf ("Last inserted record has id %d\n", mysql_insert_id());

?> `

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号