MySQL条件连接

MySQL条件连接,mysql,sql,mysql-error-1064,Mysql,Sql,Mysql Error 1064,如下所示,我正在检查当前用户是否在表朋友的user\u a或user\u b列中 根据当前用户所在的位置,我想找到他相应的朋友 不知何故,我无法使用这种语法,不知道是否有人能告诉我出了什么问题(如果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

如下所示,我正在检查当前用户是否在表朋友
user\u a
user\u b
列中

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

不知何故,我无法使用这种语法,不知道是否有人能告诉我出了什么问题(如果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;

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

如果您可以使用局部变量,那么可以采用以下方法:

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;

我也不确定这是否正确,但它可能会让您走上正确的道路。另请参见:

您正在发明语法。MySQL中的“如果”支持如下:

  • 语句,用于存储过程和触发器。文档:

  • 函数,用于为结果列选择一个备用表达式。文档:


  • 你似乎在做完全不同的事情。

    你可以通过工会来做:

    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;
    

    你是说在
    SELECT
    语句中的任何位置使用
    IF
    JOIN
    WHERE
    吗?@torr是的,我的意思是在
    SELECT
    语句中的任何位置使用
    IF
    并期望它动态地构造一个完整有效的SQL语句。好吧,似乎大家都认为这是一些蹩脚的mySQL代码——有人有什么建议吗/我实现我想要的结果的路线图?如果你解释你实际想要实现的目标,这会更容易帮助。你可以通过工会来实现……请参阅我的答案。thx@dkamins,如果你有其他选择,请告诉我query@AJ-很好,这很好--@AJ您能编辑您的回复,在中添加
    并接受=1
    吗第3行和第7行?这完成了我的原始问题,并允许我的查询过滤掉仍在等待的友谊(即,已接受=0)-非常感谢