2013-02-19 129 views
0

我有一個.xml頁,我想從每6小時拉數據。如果陳述檢查是否有東西存在,否則更新

然後將此數據插入到數據庫中,並將唯一密鑰設置爲「characterID」。

然後代碼需要根據其結果檢查下面的一個操作。

  1. 如果.XML文件包含characterID尚未在數據庫中添加行!

  2. 如果數據庫在.XML刪除行中包含characterID NOT!

  3. 如果.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刪除行和替換」相關的一些其他信息表否則我將在該行中手動添加時,鬆散的相關數據。

+0

這裏的網站不能很好地與代碼工作。您基本上正在尋找一種方法來將數據庫數據與來自不同數據存儲區(這裏是XML)的數據同步。理論上來說,解決這個問題最好是得到一些代碼必須寫在最後的想法。 – hakre 2013-02-20 18:18:06

回答

0

你可以先用CharacterID做一個SELECT聲明。比你可以檢查rowcount是否等於1.如果是這種情況,你可以更新你的行,否則你在數據庫中插入一個新行。

+0

我將如何編寫if語句來執行檢查?即時通訊php新手:p – 2013-02-19 12:13:15

+0

好吧,我寫了這個, http://pastebin.com/P5EahPVk 我剛剛試圖運行時得到「查詢是空的」。 – 2013-02-19 12:58:34

相關問題