Данные не попадают в базу данных во время цикла - PullRequest
0 голосов
/ 16 января 2012

Я написал ниже, чтобы извлечь данные из веб-страницы, но это работает постоянно без вставки данных в таблицу.Как мне разбить этот транскрипт в приведенном ниже коде.

Я хочу вставить для каждого URL немедленно и зафиксировать в цикле.Это не работает:

<?php
// example of how to use basic selector to retrieve HTML contents
ini_set('log_errors','0');
ini_set('display_errors','1');
error_reporting(2047);
include('simple_html_dom.php');
include('parameters.php');
// get DOM from URL or file

set_time_limit(0);
$site_name="sitename";
mysql_connect($hostname, $user, $pass) or
                die("Could not connect: " . mysql_error());
mysql_select_db($database);
$query="select site_name,category,subcategory,link,first_no,last_no 
        from `search_links` where site_name='".$site_name."'";

echo $query;
$res=mysql_query($query);

while ($row = mysql_fetch_assoc($res)) 
{      
    $links[]=array(
        "site_name"=>$row["site_name"],
        "category"=>$row["category"],
        "subcategory"=>$row["subcategory"],
        "url"=>$row["link"],
        "first_no"=>$row["first_no"],
        "last_no"=>$row["last_no"]);    
}

foreach ($links as $link)    
{
    for ($i=$link["first_no"];$i<$link["last_no"];$i++)
    {
        try 
        {
            $html = file_get_html($link["url"].$i);    
            $sql = array();
            foreach($html->find('a') as $e)
            {
                $sql[] = "('".$e->href."',
                    '".$site_name."',
                    '".$link["category"]."',
                    '".$link["subcategory"]."','N')";
            }
            #var_dump($sql);
            mysql_connect($hostname, $user, $pass) or
                die("Could not connect: " . mysql_error());
            mysql_select_db($database);

            $sql_ext=" ON DUPLICATE KEY update duplicate='Y'";
        /*//echo('INSERT INTO table (link,site,category,subcategory, archived) 
            VALUES '.implode(',', $sql));*/
            mysql_query(
                'INSERT INTO classifieds (link,site,category,subcategory, archived)
                VALUES '.implode(',', $sql).$sql_ext);    
            mysql_query("COMMIT");
        }
        catch(Exception $e)
        {
            echo 'Message: ' .$e->getMessage();
        }
    }
}
?>

1 Ответ

1 голос
/ 16 января 2012

Расширение mysql не генерирует исключения.
поэтому либо используйте регулярные сообщения об ошибках

$sql = 'INSERT INTO classifieds (link,site,category,subcategory, archived)
        VALUES '.implode(',', $sql).$sql_ext;
mysql_query($sql) or trigger_error(mysql_error().$sql); 

или выбросить исключение таким образом

if (!mysql_query($sql)) {
   throw new Exception(mysql_error().$sql); 
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...