php中如何同时执行两个不同的insert语句

bingyilingdu 2012-05-07 09:25:44
<?php
class SqlTool{
public $link;
public $hostName="localhost";
public $userName="root";
public $userPwd="";
public $db_Name="qlzx";
public function execute_dml($sql){
$res=$this->link->query($sql) or die($this->link->error);
if(!$res) return 0;
else{
if($this->link->affected_rows>0) return 1;
else return 2;
}
}
}
$sqlTool=new SqlTool();

$sql="insert into customerinfo values(null,'{$ci->getEmail()}','{$ci->getPwd()}',now())";
$sql.="insert into customerdetailinfo values(last_insert_id(),'{$cdi->getName()}','{$cdi->getTelphone
()}','{$cdi->getMovePhone()}','{$cdi->getAddress()}')";

$sqlTool->execute_dml($sql);

?>

这样执行语句能否成功?
...全文
176 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
码无边 2012-05-08
  • 打赏
  • 举报
回复
用事务处理。
xuzuning 2012-05-08
  • 打赏
  • 举报
回复
不能!
一次只能执行一条 SQL 指令,这是 php 内置的 防范SQL攻击 的措施,不要试图突破他
分开来执行也是一样的,只要数据库连接没断开过

改一下昵称 2012-05-07
  • 打赏
  • 举报
回复
分开写,费不了多少事。
last_insert_id() 这么做完全没必要,ID是自增的,那么就不需要你去指定。任何数据库的设计者都会考虑到自增键可能出现的任何问题,并在开发阶段就能解决。
helloyou0 2012-05-07
  • 打赏
  • 举报
回复
用事务
bingyilingdu 2012-05-07
  • 打赏
  • 举报
回复
加个分号隔开也不行,last_insert_id()是获取的前一个insert语句中的id(自动增长),我考虑是线程安全,我才学一个多月不太懂。
改一下昵称 2012-05-07
  • 打赏
  • 举报
回复
不能,至少你SQL语句之间还应该有个分号来隔开。
我更好奇的是为什么你会有这么奇怪的需求,分开执行不仅方便排错,而且安全

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧