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

本文介绍了如何在MySQL数据库中进行跨表搜索,包括利用左联接(left join)、右联接(right join)和INNER JOIN找到关联字段值。同时,还探讨了使用UNION操作符来合并两个查询结果,通过删除重复数据以获得独特的搜索结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

同时搜索字段值(有关联关系)使用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)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值