0

我有一个关于 SQL 的问题,我给出了一个小脚本,它从 twitter 获取人们对某人的评价,并将其从我的服务器插入到一个 sql 表中,代码运行良好,但我的问题是,脚本如何跳过一个条目当它已经存在于表中时,它会多次插入相同的条目,这里是代码:

    <?php
include '../config/config.php';
mysql_connect($dbhost, $dbuser, $dbpwrd) or die(mysql_error());
mysql_select_db($database) or die(mysql_error());

$rss = simplexml_load_file("http://search.twitter.com/search.rss?q=YaninGarciaD");
if($rss){
echo '<ul>';
foreach($rss->channel->item as $item){
            $author = (string) $item->author; // Title
            $link = (string) $item->link; // Url Link
            $description = (string) $item->description;
            $pubDate = (string) $item->pubDate; //Description

            list($usuario, $nombre3) = explode("@", $author);           
            list($basura, $nombre2) = explode(" (", $nombre3);
            $nombre = substr($nombre2, 0, -1);

            $piezasurl = explode("/", $link);
            $status = $piezasurl[5];
            $piezasfecha = explode(" ", $pubDate);

            if ($piezasfecha[2] == "Jan") {
            $mes = "01";
            } elseif ($piezasfecha[2] == "Feb") {
            $mes = "02";
            } elseif ($piezasfecha[2] == "Mar") {
            $mes = "03";
            } elseif ($piezasfecha[2] == "Apr") {
            $mes = "04";
            } elseif ($piezasfecha[2] == "May") {
            $mes = "05";
            } elseif ($piezasfecha[2] == "Jun") {
            $mes = "06";
            } elseif ($piezasfecha[2] == "Jul") {
            $mes = "07";
            } elseif ($piezasfecha[2] == "Ago") {
            $mes = "08";
            } elseif ($piezasfecha[2] == "Sep") {
            $mes = "09";
            } elseif ($piezasfecha[2] == "Oct") {
            $mes = "10";
            } elseif ($piezasfecha[2] == "Nov") {
            $mes = "11";
            } elseif ($piezasfecha[2] == "Dic") {
            $mes = "12";
            }

            $fecha = $piezasfecha[3].'-'.$mes.'-'.$piezasfecha[1].' '.$piezasfecha[4];


mysql_query("INSERT INTO yg_mensajes 
(nombre, mensaje, twitter, url, postid, tipo, fecha, aprovado)
VALUES ('$nombre', '$description', '$usuario', '$link', '$status', 2, '$fecha', 0 ) ") 
or die(mysql_error());              

echo '<li>';
echo $description.'<br />';
echo $usuario.'<br />';
echo $nombre.'<br />';
echo $link.'<br />';
echo $status.'<br />';
echo $fecha.'<br />';
echo '<br /></li>';

}
echo '</ul>';
}
?>

twitter 的一个好处是帖子编号(在此代码中是 var $status)是唯一的,即之前不应该在表中的 var

您可以在此处查看正在运行的脚本: http ://www.yaningarcia.com/unete/test.php

我的 SQL 表结构是这样的:

 CREATE TABLE `yg_mensajes` (
  `id` int(11) NOT NULL auto_increment,
  `nombre` text,
  `mensaje` text,
  `twitter` text,
  `url` text,
  `postid` text,
  `tipo` int(11) default NULL,
  `fecha` datetime default NULL,
  `aprovado` int(11) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

谢谢!!:D

4

2 回答 2

2

您可以使用INSERT IGNORE...INSERT...ON DUPLICATE UPDATE..命令。

http://www.electrictoolbox.com/mysql-insert-ignore/

http://www.mysqlperformanceblog.com/2006/05/29/insert-on-duplicate-key-update-and-summary-counters/

希望能帮助到你...

于 2012-04-04T07:04:52.200 回答
0

我认为,您需要在 postid 字段上创建索引并使用 INSERT IGNORE 命令。或使用 INSERT...ON DUPLICATE KY UPDATE,但在这种情况下,您需要更新一个或多个字段 http://dev.mysql.com/doc/refman/5.6/en/insert.html

于 2012-04-04T07:08:53.543 回答