子查询
子查询(Subquery),也被称为嵌套查询(Nested Query),是指在一个查询语句中嵌套使用另一个完整的查询语句。子查询可以被视为一个查询的结果集,它可以作为外层查询的一部分,用于进一步筛选、计算或操作数据。
子查询通常出现在主查询的WHERE子句、FROM子句、HAVING子句或SELECT子句中,以提供更复杂的查询逻辑。子查询可以根据主查询的结果动态生成结果集,用于过滤和匹配数据,或者作为函数的参数使用。
子查询可以返回单个值、一列值、一行值或者一个结果集,具体取决于子查询的语法和用法。根据子查询返回的结果类型,可以将其与主查询的其他表达式进行比较、连接或使用作为条件进行过滤。
我们之前的案例都是在一张表去查询,现实中不会把所有东西都放在一张表,会进行分表,甚至还会分库分表,读写分离等等。
案例通过名字查询photo表
photo表数据
user表数据
关联关系为 user表的id 关联 photo表的user_id
但是我们现在需要通过名字查询出photo表的数据 但是photo表没有存名字怎么弄
子查询
我们的思路就是通过名字查询user表的id,然后通过user表的id去查询photo的user_id就完成了
SELECT * FROM `photo` WHERE `user_id` = (SELECT id FROM `user` WHERE name = '小满')
连表
Mysql的连表分为内连接,外连接,交叉连接
- 对于
内连接
的两个表,驱动表中的记录在被驱动表中找不到匹配的记录,该记录不会加入到最后的结果集,我们上边提到的连接都是所谓的内连接
。 - 对于
外连接
的两个表,驱动表中的记录即使在被驱动表中没有匹配的记录,也仍然需要加入到结果集。 交叉连接
是指在两张或多张表之间没有任何连接条件的连接。简单来说,交叉连接
可以让你查询所有可能的组合。
内连接
SELECT * FROM `user`, `photo` WHERE `user`.`id` = `photo`.`user_id`
外连接
左连接
语法规则 LEFT JOIN [连接的表] ON [连接的条件]
并且以第一个表作为驱动表
被驱动表如果没有值则补充null
SELECT * FROM `user` LEFT JOIN `table` ON `user`.`id` = `table`.`user_id`
右连接
语法规则 LEFT JOIN [连接的表] ON [连接的条件]
并且以第二个表作为驱动表
被驱动表如果没有值则忽略
SELECT * FROM `user` RIGHT JOIN `table` ON `user`.`id` = `table`.`user_id`