TP5.1执行SQL文件创建多个数据表MySQL提示42000错误解决方案

7 篇文章 0 订阅
 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());
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值