0

6時間ごとにデータを取得したい.xmlページがあります。

次に、このデータがデータベースに挿入され、一意のキーが「characterID」として設定されます。

次に、コードは、その結果に基づいて、次のパフォーマンスアクションをチェックする必要があります。

  1. .XMLファイルにまだデータベースにないcharacterIDが含まれている場合は、行を追加してください。

  2. データベースに.XML削除行にないcharacterIDが含まれている場合!

  3. .XMLファイルの行がデータベースの行と異なる場合(CHARACTERIDは異なりませんが、他のデータは異なります)、新しい情報で行を更新します。ここで、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 に答える