<?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);?>这样执行语句能否成功?

解决方案 »

  1.   

    不能,至少你SQL语句之间还应该有个分号来隔开。
    我更好奇的是为什么你会有这么奇怪的需求,分开执行不仅方便排错,而且安全
      

  2.   

    加个分号隔开也不行,last_insert_id()是获取的前一个insert语句中的id(自动增长),我考虑是线程安全,我才学一个多月不太懂。
      

  3.   

    分开写,费不了多少事。
    last_insert_id()  这么做完全没必要,ID是自增的,那么就不需要你去指定。任何数据库的设计者都会考虑到自增键可能出现的任何问题,并在开发阶段就能解决。
      

  4.   

    不能!
    一次只能执行一条 SQL 指令,这是 php 内置的 防范SQL攻击 的措施,不要试图突破他
    分开来执行也是一样的,只要数据库连接没断开过