MySQL条件加入

时间:2011-06-04 02:47:06

标签: mysql sql mysql-error-1064

如下所示,我正在检查当前用户是否在表朋友user_auser_b列中。

根据当前用户的位置,我想找到他相应的朋友。

不知怎的,我无法使用这种语法,并想知道是否有人可以告诉我什么是错的(我在IF user_a = 2附近的第3行收到错误。

SELECT *
  FROM friends
IF user_a = 2 THEN
  JOIN user_profiles ON friends.user_b = user.profiles.user_id
 WHERE user_a = 2
   AND accepted = 1;
ELSEIF user_b = 2 THEN
  JOIN user_profiles ON friends.user_a = user_profiles.user_id
 WHERE user_b = 2
   AND accepted = 1;
END IF;

3 个答案:

答案 0 :(得分:8)

您可以使用UNION执行此操作:

select f.*, up_a.* from friends f
  inner join user_profiles up_a on f.user_a=up_a.user_id
  where f.user_b=2 and f.accepted=1
union
select f.*, up_b.* from friends f
  inner join user_profiles up_b on f.user_b=up_b.user_id
  where f.user_a=2 and f.accepted=1;

答案 1 :(得分:3)

您正在发明语法。 MySQL中的“IF”支持为:

  1. 语句,用于存储过程和触发器。文档: http://dev.mysql.com/doc/refman/5.0/en/if-statement.html

  2. 功能,用于为结果列选择一个备用表达式。文档:http://dev.mysql.com/doc/refman/5.0/en/control-flow-functions.html#function_if

  3. 您似乎完全在做其他事情。

答案 2 :(得分:0)

我相信您尝试使用的语法不受支持。我不认为您可以使用IF条件以这种方式分支您的SQL语句。可以将其放入SELECT CASE

如果您可以使用局部变量,则可以使用以下某些内容:

BEGIN
SELECT user_a, user_b INTO local_a, local_b FROM friends;

IF local_a = 2 THEN
  SELECT * FROM friends JOIN user_profiles ON friends.user_b = users.profiles.user_id
  WHERE user_a = 2 AND accepted = 1;
ELSEIF user_b = 2 THEN
  SELECT * FROM friends JOIN user_profiles ON friends.user_b = users.profiles.user_id
  WHERE user_b = 2 AND accepted = 1
END IF;
END;

我不确定这种情况的有效性,但它可能会让你走上正确的道路。另见:http://dev.mysql.com/doc/refman/5.0/en/select-into-statement.html