SQLSTATE[42000]: Syntax error or access violation
SQL 文件大体如下:
CREATE TABLE `du_code` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`shop_id` int(11) NOT NULL DEFAULT '0' COMMENT '店铺ID',
PRIMARY KEY (`id`),
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
--page--
CREATE TABLE `du_code_ext` (
`code_id` int(11) NOT NULL AUTO_INCREMENT,
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
以上只是示例,中间删除N多字段。当有多个Create Table的时候,会报上面的42000错误,当你把整个个SQL文件放到phpMyAdmin中执行的时候发现是正常的。
这就不是SQL文件的问题了。经过实验发现,当执行一个CreateTable的时候是正常的。多个就不行。这也好办,把一个SQL文件分隔成多个cretateTable就可以了。
如上代码,在多个createTable中间加入 --page-- 然后把sql分隔成多个就可以执行了。完成任务。
说明: -- 在SQL 文件中是注释的意思,经常用PHPMyAdmin导出的就会发现,里面有很多-- 这样做不会影响在sql中导入执行。
$tableArr = explode('--page--',$sql);
try{
foreach ($tableArr as $tSql){
Db::execute($tSql);
}
}catch (\Exception $e){
return $this->error($e->getMessage());
}