php - SQL - 获取 RSS 提要并插入到 SQL 中

标签 php mysql curl pdo rss

问题:如何获取 RSS FEED 并将其插入 MySQL?

我想从 rss feed 获取并插入数据,在本例中为 kotakus rss feed (kotaku.com/vip.xml)。

目前:我在 PDO 方法中遇到错误: 解析错误:语法错误,第 11 行 D:\xampp\htdocs\xml\sql_pdo.php 中出现意外的“(”

我将展示三个步骤的代码。 首先获取当前正在运行的数据。 第二是一种 PDO 方法,用于获取数据并将数据插入到 mySQL 中(当前不工作)。 第三与第二个相同,但使用 Curl 代替(也不起作用)。我使用 PhpMyAdmin 和 Xampp 作为 MySQL 数据库。我只想要第二种或第三种方法或另一种方法起作用..唯一重要的是获得结果。

第一个代码:

<?php
$xml= simplexml_load_file("http://kotaku.com/vip.xml"); 
foreach($xml->channel->item as $itm){
    $title = $itm->title;
    $description = $itm->description;
    echo $title;
    echo $description;
} ?>

第二个(PDO)

<?php
$db = new PDO('mysql:host=localhost;dbname=simpledata','root','123456');

$xmldoc = new DOMDocument();
$xmldoc = load('http://kotaku.com/vip.xml');

$xmldata = $xmldoc->getElementsByTagName('channel');
$xmlcount = $xmldata->length;

for ($i=0; $i < $xmlcount; $i++) {
    $title = $xmldata->item($i)->getElementsByTagName('title')(0)->childNodes->item(0)->nodeValue;
    $description = $xmldata->item($i)->getElementsByTagName('description')(0)->childNodes->item(0)->nodeValue;

    $stmt = $db->prepare("insert into kotaku values(?,?)");
    $stmt->bindParam(1,$title);
    $stmt->bindParam(1,$description);
    $stmt->execute();
    printf($title);
} ?>

第三个( curl )

<?php

$url="http://kotaku.com/vip.xml"; //need complete
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl-setopt($ch, CURLOPT_URL, $url);  //get the url contents

$data = curl_exec ($ch); //execute curl request
curl_close($ch);

$xml = simplexml_load_string($data);

$con=mysql_connect("localhost","root","123456"); //connect to server 
mysql_select_db("simpledata", $con) or die (mysql_error()); //select database

foreach ($xml -> item as $row) {
    $title = $row -> title;
    $description = $row -> description;

// performing sql query

$sql = "INSERT INTO 'kotaku' ('title', 'description')"
        . "VALUES ('$title', '$description')";

$result = mysql_query($sql);
if (!$result) {
    echo 'MySQL ERROR';
    } else {
    echo 'SUCCES';
    }
?>

最佳答案

如果不指定绑定(bind)数据类型,则无法使用 pdo bindParam。 使用bindValue代替:

  $stmt->bindValue(1, $title);
  $stmt->bindValue(2, $description);

关于php - SQL - 获取 RSS 提要并插入到 SQL 中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44482645/

相关文章:

php - 使用 Symfony 2 事件调度程序

php - MySQL 不会将 for 循环中的最后一项插入数据库

mysql - mysql列中的时间戳

node.js - 使用 node-libcurl 进行 Curl JSON Post

winapi - 在 Windows 上构建支持 SSL 的 libcurl

php - 来自 BASH 的 Tcpdump

php - Zend Framework 中的单元测试 json 输出

php - 比较 MYSQL 时间戳以检索以特定单位传递的时间

MySQL 按多列排序(id 和整数)

php - 在 foreach 循环中使用 cURL (php)