0

この機能を動作させるにはどうすればよいですか? 最後のクエリが実行されません..ループ内のクエリをたくさん検索しましたが(foreach、for、while)、何もありません..セッションを保存しようとしています。

private function gc($expire)
{
  $gcq = "SELECT `path`, `last`, LENGTH(`path`) FROM `sessions` WHERE LENGTH(`path`) > 0  AND DATE_ADD(`last`, INTERVAL ".(int) $expire." SECOND) < NOW();";
  $gcq .= "DELETE FROM `sessions` WHERE DATE_ADD(`last`, INTERVAL ".(int) $expire." SECOND) < NOW()";
            if($this->dbh->multi_query($gcq)) 
              {
                $arr_gc = null;
                $count = 0;
                do {
                      if($result = $this->dbh->store_result()) 
                      {
                        while($row = $result->fetch_assoc()) 
                        {
                         $arr_gc[$count] = array($row['path'], $row['last']);
                         $count++;
                        }
                        $result->free();
                      }
                      if($this->dbh->more_results()) 
                      {
                        $garbage = null;
                      }
                    } 
                     while($this->dbh->next_result());
                   }
                    // no problems up here..
                    // problems from here to end....         

                    $alfa = count($arr_gc);

                    if($alfa > 0)
                    {
                      $count = 0;

                        while($count < $alfa)
                        {
                         $this->dbh->query("INSERT INTO `store_sess` SET `xpath` = '".$this->dbh->real_escape_string($arr_gc[$count][0])."', in = '".$this->dbh->real_escape_string($arr_gc[$count][1])."', out = '0000-00-00 00:00:00'");
                         $count++;
                        }                        
                    }
  return $this->dbh->affected_rows;
}

編集: store_sess テーブルの構造:

id int (autoincrement)
xpath longtext
in datetime (tried also with varchar)
out varchar 
4

1 に答える 1

0
while($count < $alfa) {
    $this->dbh->query("INSERT INTO `store_sess` SET `xpath` = '".$this->dbh->real_escape_string($arr_gc[$count][0])."', in = '".$this->dbh->real_escape_string($arr_gc[$count][1])."', out = '0000-00-00 00:00:00'");
    $count++;
} 

上記のコードはあまりスケーラブルではありません。代わりに、クエリ全体を設定し (1 つのクエリで複数の挿入を実行できます)、クエリ文字列が設定された後に実行する必要があります。

アップデート

あなたのwhileループも不要です。

更新を終了

$insertVals = "";
for($count = 0; $count < $alfa, $count++) {
    $insertVals = ($insertVals == "" ? "" : ", ") . 
        "('" . $this->dbh->real_escape_string($arr_gc[$count][0]) . "', '" . 
        $this->dbh->real_escape_string($arr_gc[$count][1]) . 
        "', '0000-00-00 00:00:00')";
}

$query = "INSERT INTO `store_sess` (`xpath`, `in`, `out`) VALUES " . $insertVals;
于 2012-08-01T19:55:10.957 に答える