PHP PDO PDOStatement() 详解

本文详细解析PHP PDO的PDOStatement类及其使用,强调了执行SQL语句时的字符串长度限制和处理'MySQL server has gone away'错误的方法。在插入数据时,建议先关闭游标,通过循环批量添加数据,当遇到执行警告时,可通过调整相关参数解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注意事项

一:sql 语句的字符串的长度

二:插入前要关闭游标再插入

Warning: PDOStatement::execute(): MySQL server has gone away  错误发生的时候调整下 j 的最大值即可

关键代码: 

分析,通过循环来添加数据,若出现

$db = mysql::getInstance();

$num = 1;
for($i = 1; $i <= 3 ; $i++) {
  $sql = "insert into table_name (user_id, min, status) VALUES ";
  for($j = 1 ; $j <= 10000; $j++) {
    $user_id = $num + 70022;
    if ($j == 10000) {
      $sql .= "($user_id, 60, 1)";
    } else {
      $sql .= "($user_id, 60, 1),";
    }
    $num ++;
  }
  $db->query($sql);
  $db->close();
}

 

/********************** mysql 类  *************/
class mysql {

    static protected $instance = null;

    //声明数组存放数据
    private $data=array();

    //pdo对象
    private $db=NULL;

    //表名
    protected $table = '';

    protected $rootDir;

    //pdostatement类对象
    protected $stms = null;

    final protected function __construct(){

       
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值