1

我正在使用嵌套的 Foreach 循环将数据存储在 mysql 中。但它需要太多的处理时间。我怎样才能减少最大执行时间。

foreach ($results as $r) {
    mysqli_query($con,"insert into commercial values('".mysqli_real_escape_string($con,$r['MST_MLS_NUMBER'])."')");
    $val=1;
    $objects = $rets->GetObject('Property', 'Photo', $r['MST_MLS_NUMBER'], '*', 0);
    foreach ($objects as $pho) {
        mysqli_query($con,"insert into cmtval values('".mysqli_real_escape_string($con,$r['MST_MLS_NUMBER'])."')");
    }
}
4

3 回答 3

0

您应该使用批量插入

INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);

通过 foreach 循环,您应该首先执行查询,然后使用mysqli_query.

$query1 = "insert into commercial values ";
$query2 = "insert into cmtval values ";
foreach ($results as $r)
{
     $query1 .= "('" . mysqli_real_escape_string( $con, $r['MST_MLS_NUMBER']) . "'), ";

     $val=1;
$objects = $rets->GetObject('Property', 'Photo', $r['MST_MLS_NUMBER'], '*', 0);
  foreach ($objects as $pho)
  {
     $query2 .= "('" . mysqli_real_escape_string( $con, $r['MST_MLS_NUMBER']) . "'), ";
  }
}

mysqli_query($con, $query1);
mysqli_query($con, $query2);

我没有测试过代码。测试并让我知道是否缺少任何东西。批量更新减少了一些时间。

此外,如果您在单个查询中在数据库中保存了太多数据,并且如果索引太多,则插入数据需要时间。

于 2016-08-03T07:16:34.273 回答
0

你可以做这样的东西

foreach ($results as $r)
{
  mysqli_query($con,"insert into commercial values('".mysqli_real_escape_string($con,$r['MST_MLS_NUMBER'])."')");

    $val=1;
    $objects = $rets->GetObject('Property', 'Photo', $r['MST_MLS_NUMBER'], '*', 0);


    // generate partial query strings for insert multiple records
    $numbers=array();
    foreach ($objects as $pho)
    {
        $numbers[]= "('".mysqli_real_escape_string($con,$pho['MST_MLS_NUMBER'])."')";

    }

    mysqli_query($con,"insert into cmtval values".implode(",",$numbers)); // it will insert multiple record 
}
于 2016-08-03T07:18:16.547 回答
0

您可以使用准备语句并使用要插入的不同值执行

例如

// prepare and bind
$stmt = $conn->prepare("INSERT INTO MyGuests (firstname, lastname, email) VALUES (?, ?, ?)");
$stmt->bind_param("sss", $firstname, $lastname, $email);

// set parameters and execute
$firstname = "John";
$lastname = "Doe";
$email = "john@example.com";
$stmt->execute();

$firstname = "Mary";
$lastname = "Moe";
$email = "mary@example.com";
$stmt->execute();

$firstname = "Julie";
$lastname = "Dooley";
$email = "julie@example.com";
$stmt->execute();

设置参数和执行行应该在你的 foreach 循环中。

准备好的语句和绑定参数 准备好的语句是一种用于高效重复执行相同(或相似)SQL 语句的功能。

准备好的语句基本上是这样工作的:

准备:创建一个 SQL 语句模板并将其发送到数据库。某些值未指定,称为参数(标记为“?”)。示例: INSERT INTO MyGuests VALUES(?, ?, ?) 数据库对 SQL 语句模板进行解析、编译和查询优化,并存储结果而不执行它 执行:稍后,应用程序将值绑定到参数,然后数据库执行该语句。应用程序可以使用不同的值多次执行该语句

于 2016-08-03T07:32:37.867 回答