IF语句无法正常工作 - >比较两个表并返回值

时间:2012-03-06 21:12:48

标签: php database if-statement

我有以下问题:我想比较两个表,看看两者是否是相同的数字。如果两者都是相同的数字,那么我想更新第一个表并返回值“他在数据库中”,如果不是,则反之亦然。

以下是我的工作:

<?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);

?>

此刻它总是返回第一个回声(即使它不是真的),因此向每个数字添加相同的值。

1 个答案:

答案 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);