0

我有一个 .xml 页面,我想每 6 小时提取一次数据。

然后将此数据插入数据库,并将唯一键设置为“characterID”。

然后代码需要根据其结果检查以下执行操作。

  1. 如果 .XML 文件包含数据库中尚未包含的 characterID,则添加该行!

  2. 如果数据库包含不在 .XML 删除行中的字符 ID!

  3. 如果 .XML 文件中的一行与数据库中的行不同(CHARACTERID 不会不同,但其他数据会),则使用新信息更新该行 WHERE charactedID 是相同的!

是我当前的源代码,它循环通过 XML 并正确插入数据,但我无法更新信息。

<?php
// INCLUDE DB CONNECTION FILE
include("includes/connect.php");

// CHANGE THE VALUES HERE
include("includes/config.php");

// URL FOR XML DATA
$url = "test.xml"; // For Testing Purposes

// RUN XML DATA READY FOR INSERT
$xml = simplexml_load_file($url);

// RUN SQL to check data already in table
$sql = mysql_query("SELECT * from `ecmt_memberlist`");

// Loop Through Names
foreach ($xml->result->rowset[0] as $value) {

$characterID = mysql_real_escape_string($value['characterID']);
$name = mysql_real_escape_string($value['name']);
$startDateTime = mysql_real_escape_string($value['startDateTime']);
$baseID = mysql_real_escape_string($value['baseID']);
$base = mysql_real_escape_string($value['base']);
$title = mysql_real_escape_string($value['title']);
$logonDateTime = mysql_real_escape_string($value['logonDateTime']);
$logoffDateTime = mysql_real_escape_string($value['logoffDateTime']);
$locationID = mysql_real_escape_string($value['locationID']);
$location = mysql_real_escape_string($value['location']);
$shipTypeID = mysql_real_escape_string($value['shipTypeID']);
$shipType = mysql_real_escape_string($value['shipType']);
$roles = mysql_real_escape_string($value['roles']);
$grantableRoles = mysql_real_escape_string($value['grantableRoles']);


// NOW LETS INSERT INTO DATABASE!!
$query = "INSERT INTO `ecmt_memberlist` SET
characterID='$characterID',
name='$name',
startDateTime='$startDateTime',
baseID='$baseID',
base='$base',
title='$title',
logonDateTime='$logonDateTime',
logoffDateTime='$logoffDateTime',
locationID='$locationID',
location='$location',
shipTypeID='$shipTypeID',
shipType='$shipType',
roles='$roles',
grantableRoles='$grantableRoles'";

//echo query to error check
echo $query;
echo "<br><br>";

mysql_query($query) or die(mysql_error());
};
?>

插入的表还将包含一些其他信息,这些信息将与 characterID 相关联,因此需要“不删除行并替换”,否则在手动添加时我将丢失该行中的关联数据。

4

1 回答 1

0

你可以先SELECT用 CharacterID 做一个语句。你可以检查行数是否等于 1。如果是这种情况,你可以更新你的行,否则你在数据库中插入一个新行。

于 2013-02-19T11:06:11.373 回答