我有以下问题:我想比较两个表,看看两者是否是相同的数字。如果两者都是相同的数字,那么我想更新第一个表并返回值“他在数据库中”,如果不是,则反之亦然。
以下是我的工作:
<?php
$DB_HostName = "localhost";
$DB_Name = "db";
$DB_User = "user";
$DB_Pass = "";
$DB_Table = "Relation";
$DB_Table2 = "Contacts";
$con = mysql_connect($DB_HostName,$DB_User,$DB_Pass) or die (mysql_error());
mysql_select_db($DB_Name,$con) or die(mysql_error());
$result = mysql_query("SELECT User FROM $DB_Table left join $DB_Table2 on User = Number", $con);
if ($result) {
if (mysql_num_rows($result) > 0) {
echo "This user is already in database";
mysql_query("update $DB_Table2 SET Echo ='http://activity.24.eu/images /thumbsup.png'");
}
else {
echo "This user isn't in the database";
mysql_query("update $DB_Table2 SET Echo ='http://activity.24.eu/images/thumbsdown.png'");
}
}
mysql_close($con);
?>
此刻它总是返回第一个回声(即使它不是真的),因此向每个数字添加相同的值。
答案 0 :(得分:1)
您在查询中执行左外连接,这意味着结果将包含表 Relation 的所有行,无论它们是否在 Contacts 中都有相应的行。< / p>
部分on User = Number
属于联接,描述了哪些列构成关系。如果这些是您要比较的属性,则应将它们放入WHERE部分:
SELECT User FROM Relation left join Contacts on (Relation.field = Contacts.field) WHERE User = Number
顺便说一句,您应该注意,您放入SQL字符串的所有变量都已正确转义,以防止SQL注入。
修改强> 根据评论,我试着举个例子:
如果您想要一个具有相应Contacts.Number的所有用户的列表,请写下:
SELECT Relation.User FROM Relation INNER JOIN Contacts ON (Relation.User = Contacts.Number)
结果将是一个列表行,每行包含一个Relation.User值。现在你可以循环遍历这些行并创建一个类似于8,77,81,...。
的字符串要更新您的表格,您可以编写以下2个更新:
UPDATE Contacts SET Echo = 'thumbsup' WHERE Contacts.Number IN (8,77,81);
UPDATE Contacts SET Echo = 'thumbsdown' WHERE Contacts.Number NOT IN (8,77,81);