php中怎么同时执行两个不同的insert语句
程序员文章站
2024-02-04 11:43:46
...
php中如何同时执行两个不同的insert语句
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);
?>
这样执行语句能否成功?
------解决方案--------------------
不能,至少你SQL语句之间还应该有个分号来隔开。
我更好奇的是为什么你会有这么奇怪的需求,分开执行不仅方便排错,而且安全
------解决方案--------------------
用事务
------解决方案--------------------
分开写,费不了多少事。
last_insert_id() 这么做完全没必要,ID是自增的,那么就不需要你去指定。任何数据库的设计者都会考虑到自增键可能出现的任何问题,并在开发阶段就能解决。
------解决方案--------------------
不能!
一次只能执行一条 SQL 指令,这是 php 内置的 防范SQL攻击 的措施,不要试图突破他
分开来执行也是一样的,只要数据库连接没断开过
------解决方案--------------------
用事务处理。
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);
?>
这样执行语句能否成功?
------解决方案--------------------
不能,至少你SQL语句之间还应该有个分号来隔开。
我更好奇的是为什么你会有这么奇怪的需求,分开执行不仅方便排错,而且安全
------解决方案--------------------
用事务
------解决方案--------------------
分开写,费不了多少事。
last_insert_id() 这么做完全没必要,ID是自增的,那么就不需要你去指定。任何数据库的设计者都会考虑到自增键可能出现的任何问题,并在开发阶段就能解决。
------解决方案--------------------
不能!
一次只能执行一条 SQL 指令,这是 php 内置的 防范SQL攻击 的措施,不要试图突破他
分开来执行也是一样的,只要数据库连接没断开过
------解决方案--------------------
用事务处理。
相关文章
相关视频
上一篇: ThinkPHP显示中文验证码,仅显示一个字解决方案
下一篇: DATE_FORMAT如何用