同时搜索字段值(有关联关系)使用
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)