2012-08-01 3 views
0

Как я могу настроить эту функцию? Последний запрос не выполняется. Я много раз искал запросы в цикле (foreach, for, while), но ничего .. Я пытаюсь хранить сеансы. Структура store_sess таблицы::multi query + single query

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; 
} 

РЕДАКТИРОВАТЬ

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

Вы уверены, что '$ alfa'> 0, верно? – Matt

+0

Да, теперь я отлаживаю с alfa = 2 – lollo

ответ

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++; 
} 

Приведенный выше код не очень масштабируемым. Вместо этого вы должны полностью настроить свой запрос (вы можете сделать несколько вложений с одним запросом) и выполнить его после того, как строка запроса была настроена.

UPDATE

Ваш while цикл также не требуется.

END UPDATE

$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; 
+0

спасибо ... попробуем позже ... :) bye – lollo

+0

.. очень хорошая идея, спасибо .. однако я запустил ее с небольшим изменением '$ insertVals. = ($ insertVals == ""? "": ",") ..... 'ecc .... (обратите внимание на точку before =) bye – lollo