从XML插入数据到MySQL

时间:2014-01-14 01:59:56

标签: php mysql xml foreach

我正在尝试从XML检索数据并将其插入MySQL,但数据不断重复或循环,不确定如何修复它。

这是我的PHP脚本,它通过audioscrobbler.com API获取XML数据。 (参见页面中的完整XML数据)

$artist = 'metallica';
$title = 'whiskey in the jar';
$xml = simplexml_load_file("http://ws.audioscrobbler.com/2.0/?method=track.getInfo&api_key=$myAPIkey&artist=$artist&track=$title") or die("Error: Cannot create object");

foreach($xml->track->children() as $track => $data){

      $song_album .= $data->title;
      $song_tag = $data->tag->name[0];
      $song_imageURL .= $data->image[2];

  $xml = NULL;

}

我正在将这些值插入MySQL并且可以正常运行,但是使用 $ song_album $ song_tag 我会一遍又一遍地重复相同的数据,我找不到只插入一次文本值的方法。

这是插入行后 * song_album * 列在mysql中的样子:

 Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.Garage, Inc.

它应该只是:

Garage, Inc.

以下是插入该行后 * song_tag * 列在mysql中的样子:

metalmetalmetalmetalmetalmetalmetalmetalmetalmetalmetalmetalmetal

它应该只是:

metal

这是XML原始数据:

<lfm status="ok">
<track>
<id>1003737</id>
<name>Whiskey in the Jar</name>
<mbid>664ae92a-f25a-4df4-a564-66ee87dff1c8</mbid>
<url>...</url>
<duration>303000</duration>
<streamable fulltrack="0">0</streamable>
<listeners>433263</listeners>
<playcount>3389216</playcount>
<artist>
<name>Metallica</name>
<mbid>65f4f0c5-ef9e-490c-aee3-909e7ae6b2ab</mbid>
<url>http://www.last.fm/music/Metallica</url>
</artist>
<album position="9">
<artist>Metallica</artist>
<title>Garage, Inc.</title>
<mbid/>
<url>http://www.last.fm/music/Metallica/Garage,+Inc.</url>
<image size="small">http://userserve-ak.last.fm/serve/64s/54059755.png</image>
<image size="medium">http://userserve-ak.last.fm/serve/126/54059755.png</image>
<image size="large">http://userserve-ak.last.fm/serve/174s/54059755.png</image>
<image size="extralarge">http://userserve-ak.last.fm/serve/300x300/54059755.png
</image>
</album>
<toptags>
<tag>
<name>metal</name>
<url>http://www.last.fm/tag/metal</url>
</tag>
<tag>
<name>heavy metal</name>
<url>http://www.last.fm/tag/heavy%20metal</url>
</tag>
<tag>
<name>hard rock</name>
<url>http://www.last.fm/tag/hard%20rock</url>
</tag>
<tag>
<name>rock</name>
<url>http://www.last.fm/tag/rock</url>
</tag>
<tag>
<name>cover</name>
<url>http://www.last.fm/tag/cover</url>
</tag>
</toptags>
<wiki>...</wiki>
</track>
</lfm>

感谢。

2 个答案:

答案 0 :(得分:2)

我不确定为什么你连接字符串,我试验你的代码,这似乎没问题。在变量赋值时删除了点,并为个人测试添加了mysqli代码。

<?php

error_reporting(E_ALL);

// Connect
$mysqli = new mysqli('localhost', 'root', '', 'dachi');

if (mysqli_connect_errno()) {
    printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}


$artist = 'metallica';
$title = 'whiskey in the jar';
$xml = simplexml_load_file("test.xml") or die("Error: Cannot create object");

$song_album = '';
$song_imageURL = '';

foreach($xml->track->children() as $track => $data){
    $song_album = $data->title; // I removed dot here
    $song_tag = $data->tag->name[0];

     // Remove dot if correct (can't understand just form this snippet why you concat)
    $song_imageURL .= $data->image[2];

    $xml = NULL;

    $stmt = $mysqli->prepare("INSERT INTO `test` (`test`) VALUES (?)");
    $stmt->bind_param('s', $song_album);
    $stmt->execute();
    $stmt->close();
}

?>

此外,我不确定您是否需要声明的变量。

请注意:

如果您有$text = 'dachi';

然后你给$text .= 'boy';

$text则等于'dachiboy'

所以.=用于连接,这就是你在循环中所做的事情。使用.=将相册名称分配到同一个变量,从而将它们添加到一起。

答案 1 :(得分:1)

难道你不能跳过整个循环而只是直接收集你需要的数据吗?类似的东西:

  $xml = simplexml_load_file("http://ws.audioscrobbler.com/2.0/?method=track.getInfo&api_key=$myAPIkey&artist=$artist&track=$title") or die("Error: Cannot create object");

  $song_album = $xml->track->title;
  $song_tag = $xml->track->tag[0]->name;
  $song_imageURL = $xml->track->image[2];