Как я могу настроить эту функцию? Последний запрос не выполняется. Я много раз искал запросы в цикле (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
Вы уверены, что '$ alfa'> 0, верно? – Matt
Да, теперь я отлаживаю с alfa = 2 – lollo