Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/60.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql 如果联接的一条记录不匹配,则删除联接的所有结果_Mysql_Sql_Join - Fatal编程技术网

Mysql 如果联接的一条记录不匹配,则删除联接的所有结果

Mysql 如果联接的一条记录不匹配,则删除联接的所有结果,mysql,sql,join,Mysql,Sql,Join,我有两张桌子 A ID NAME -------------- 1 A B USER_ID role -------------- 1 ADMIN 1 USER 1 ROLE2 如果我使用一个左键,则加入B where角色!='管理员:我得到两个结果。 但是,如果我不希望用户1有任何结果,因为用户的一条记录不匹配怎么办?看起来您需要一个子查询 Select * from A where ID not i

我有两张桌子

A    
ID   NAME
--------------
1    A


B
USER_ID  role
--------------
1         ADMIN
1         USER
1         ROLE2
如果我使用一个左键,则加入B where角色!='管理员:我得到两个结果。
但是,如果我不希望用户1有任何结果,因为用户的一条记录不匹配怎么办?

看起来您需要一个子查询

 Select * from A 
        where ID not in (select USER_ID from B where role = 'ADMIN')
如果只希望在B中有角色的结果,可以添加内部联接:

 Select * from A
       Inner join B on A.ID = B.User_ID
       where A.ID not in (select B2.USER_ID from B B2 where B2.role = 'ADMIN')

这将把结果限制为表B中匹配的结果和没有管理员角色的结果。

您可以使用不存在的查询:

SELECT A.*, B.*
FROM
  A INNER JOIN B
  ON A.ID = B.USER_ID
WHERE
  NOT EXISTS (SELECT * FROM B AS b2 WHERE b2.USER_ID = A.ID AND b2.ROLE = 'ADMIN')

这个问题实际上并不清楚。根据我从数据中了解到的情况

如果其案例“1”中的用户ID是管理员,则他不希望返回任何用户ID为“1”的记录。让我们把这个表扩展一下

A. 身份证名称 ------- 1A B 用户ID角色 ------- 1管理员 1用户 1角色2 2诺塔明
2角色3你想要什么结果?2个结果-2个结果=无结果。只是不要运行任何查询。不清楚你在问什么对不起,我不想要结果,因为用户id 1具有管理员角色。例如,用户2?我想他更想要具有角色但不是管理员的用户