• PHP执行批量mysql语句


    当有多条mysql语句连起来需要执行,比如

    $sqls= “insert table a values(1,2); insert table a values(2,3);”

    需要执行的话php中可以使用的方法有三个:

    mysql_query

    pdo

    mysqli

    三种方法当sqls语句没有问题的时候都是可以的

    但是

    当sql语句是错误的时候会出现问题

    第一条sql错误:三个方法都返回false

    第一条sql正确,第二条sql错误:mysql_query、pdo、 mysqli:query也是返回true。所以这个时候你是没法判断你的sqls是否有那条语句是错误的

    解决这种办法有几个招

    1 解析sql语句

    将每条sql都拆分开来执行。这样每个语句分开执行就解决了。但是这种方法多出了好几种方法,所以不可取。

    2 将sqls语句保存为文本

    使用cmd执行命令 mysql…. .< sqls.sql, 然后捕获输出。这也是一种方法,但是感觉是绕着问题走,应该还有更好的方法。

    3 使用mysqli::multi_query方法

    这个方法可以执行多条sql语句,然后使用mysqli::next_result来设置sql的偏移量,使用mysqli::error获取当前偏移的sql的错误状态

    下面是第三种方法的示例代码

    代码如下:

    $sql = Config::get('sql');
    $content = file_get_contents($sql);
    $config = Config::get('config')
    $mysqli = mysqli_connect($config['host'], $config['user'], $config['password'], $config['dbname']);
    $ret = $mysqli->multi_query($content);
    if($ret === false) {
        echo mysqli_error($mysqli);
    }
    while (mysqli_more_results($mysqli)) {
        if (mysqli_next_result($mysqli) === false) {
            echo mysqli_error($mysqli);
            echo "\r\n";
            break;
        }
    }
    $mysqli->close();

    这样的话当sqls语句中任意一条有错误的话,程序就会跳出这个错误。

    如果你要编写初始化mysql的脚本的话,这招就非常好用了。

    实时了解作者更多技术文章,技术心得,请关注微信公众号“轩脉刃的刀光剑影”

    本文基于署名-非商业性使用 3.0许可协议发布,欢迎转载,演绎,但是必须保留本文的署名叶剑峰(包含链接http://www.cnblogs.com/yjf512/),且不得用于商业目的。如您有任何疑问或者授权方面的协商,请与我联系

  • 相关阅读:
    Trying to access array offset on value of type null
    关于git的功能使用介绍
    魔法方法简介
    Celery介绍,基于django框架,场景例如短信发送。
    ksql 使用
    VSCode 运行 java project
    mongoclusterdocker
    Kafka 学习资料
    [转载] Kafka Rest Api的使用
    Windows 上连接虚拟机上docker的kafka报错unknown host
  • 原文地址:https://www.cnblogs.com/yjf512/p/2757052.html
Copyright © 2020-2023  润新知