我有一個.xml頁,我想從每6小時拉數據。如果陳述檢查是否有東西存在,否則更新
然後將此數據插入到數據庫中,並將唯一密鑰設置爲「characterID」。
然後代碼需要根據其結果檢查下面的一個操作。
如果.XML文件包含characterID尚未在數據庫中添加行!
如果數據庫在.XML刪除行中包含characterID NOT!
如果.XML文件中的行不同(CHARACTERID不會不同,但其他數據將會)到數據庫中的行UPDATE帶有新信息的行WHERE charactedID是相同的!
this是我的當前源代碼,其通過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因此需要「NOT刪除行和替換」相關的一些其他信息表否則我將在該行中手動添加時,鬆散的相關數據。
這裏的網站不能很好地與代碼工作。您基本上正在尋找一種方法來將數據庫數據與來自不同數據存儲區(這裏是XML)的數據同步。理論上來說,解決這個問題最好是得到一些代碼必須寫在最後的想法。 – hakre 2013-02-20 18:18:06