PHP执行批量mysql语句的解决方法

PHP执行批量mysql语句的解决方法,第1张

当有多条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的脚本的话,这招就非常好用了。

$value

=

''$query_num

=

5

//插入数量for($i=1$i<=$query_num$i++){

$value

.=

"('25','1')"}//mysql

insert有插入多条语法,拼接sql语句,table_name表名

$sql

=

"insert

into

table_name

(memid,online)

values

".$value//执行,插入$query_num条数据mysql_query($sql)

1、批量生成注册码的示例代码如下:

<?php

$Codes = GenCode(100)

echo '<pre>'

print_r($Codes)

echo '</pre>'

 

function GenCode($GenCount)

{

    $CodeArr = array()

    $KeyStr = '1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ'

    for ($d = 1 $d <= $GenCount $d++) {

        $CodeStr = ''   

        for ($i = 1 $i < 5 $i++) {          

            $Keys = str_shuffle($KeyStr)

            $CodeStr = $CodeStr . '-' . substr($Keys,1,4)

        }

        $CodeArr[] = substr($CodeStr,1)

    }

    

    array_unique($Codes)

    return $CodeArr

}

代码运行截图:

2、将上面的数据保存到 txt 文件,代码示例:

<?php

$Codes = GenCode(100)

SaveToTxt('./test.txt',$Codes)

function SaveToTxt($FileName, $CodeArray)

{

    $fp = fopen($FileName, "w+") or die("打开 $FileName 失败。")

    fwrite($fp, implode("\r\n", $CodeArray)) or die("写入 $FileName 数据失败。")

    fclose($fp)

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/8628604.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-19
下一篇2023-04-19

发表评论

登录后才能评论

评论列表(0条)

    保存