栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

批量参数化插入

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

批量参数化插入

好吧,您有三个选择。

  1. 一次构建-执行多次。基本上,您只需为一行准备一次插入,然后循环执行该插入。由于SQLSERVER扩展在准备好查询后不支持重新绑定查询(您需要使用reference进行肮脏的破解),所以这可能不是最佳选择。

  2. 一次构建-一次执行。基本上,您按照示例中的说明构建了一个巨型插入物,将其绑定一次,然后执行它。这有点脏,并且错过了准备查询所提供的一些好处。但是,由于需要选项1的引用,我愿意这样做。我认为构建大型查询而不是依赖变量引用会更清洁。

  3. 建立多个-执行多个。基本上,采用您正在执行的方法,并对其进行调整以每隔这么多记录重新准备查询。这样可以防止过大的查询,并使查询“成批”。所以像这样:

    $sql = 'INSERT INTO my_table (field1, field2, field3) VALUES ';

    $parameters = array();
    $data = array();

    $execute = function($params, $data) use ($my_connection, $sql) {
    $query = $sql . implode(‘, ‘, $parameters);
    $stmt = sqlsrv_prepare($my_connection, $query, $data);
    sqlsrv_execute($stmt);
    }

    while ($my_condition) {
    $parameters[] = ‘(?, ?, ?)’;
    $data[] = value1;
    $data[] = value2;
    $data[] = value3;
    if (count($parameters) % 25 == 0) {
    //Flush every 25 records
    $execute($parameters, $data);
    $parameters = array();
    $data = array();
    }
    }
    if (!empty($parameters)) {
    $execute($sql, $parameters, $data);
    }

两种方法都足够。做您认为最适合您要求的事情…



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/670436.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号