在MySQL数据库,同时搜索两个数据表中想要的数据

同时搜索字段值(有关联关系)使用join

  • left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 ;
  • right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录;
  • inner join(等值连接) 只返回两个表中联结字段相等的行;
  • 比如:同时搜索两个表里id = 2的值
select m.id,m.studername,c.classname from student m
left join class c on c.classid = m.studentclassid
where m.studentclassid = 2

搜索无关联关系的值,使用union

  • 描述
    MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

  • 语法
    MySQL UNION 操作符语法格式:

SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions]
UNION [ALL | DISTINCT]
SELECT expression1, expression2, ... expression_n
FROM tables
[WHERE conditions];
  • 参数
    • expression1, expression2, … expression_n: 要检索的列。

    • tables: 要检索的数据表。

    • WHERE conditions: 可选, 检索条件。

    • DISTINCT: 可选,删除结果集中重复的数据。默认情况下 UNION 操作符已经删除了重复数据,所以 DISTINCT 修饰符对结果没啥影响。

    • ALL: 可选,返回所有结果集,包含重复数据。

顺序搜索字段值

  • 比如:list2有,list没有的:
SELECT * FROM list WHERE NOT EXISTS 
(SELECT 1 FROM list2 WHERE list.qq = list2.qq)
  • 比如:list有,list2没有的:
SELECT * FROM list2 WHERE NOT EXISTS 
(SELECT 1 FROM list WHERE list.qq = list2.qq)

版权声明:本文为simon_xing原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。