Nodejs 第三十七章(连表and子查询)

子查询

子查询(Subquery),也被称为嵌套查询(Nested Query),是指在一个查询语句中嵌套使用另一个完整的查询语句。子查询可以被视为一个查询的结果集,它可以作为外层查询的一部分,用于进一步筛选、计算或操作数据。

子查询通常出现在主查询的WHERE子句、FROM子句、HAVING子句或SELECT子句中,以提供更复杂的查询逻辑。子查询可以根据主查询的结果动态生成结果集,用于过滤和匹配数据,或者作为函数的参数使用。

子查询可以返回单个值、一列值、一行值或者一个结果集,具体取决于子查询的语法和用法。根据子查询返回的结果类型,可以将其与主查询的其他表达式进行比较、连接或使用作为条件进行过滤。

我们之前的案例都是在一张表去查询,现实中不会把所有东西都放在一张表,会进行分表,甚至还会分库分表,读写分离等等。

案例通过名字查询photo表

photo表数据

user表数据

关联关系为 user表的id 关联 photo表的user_id

但是我们现在需要通过名字查询出photo表的数据 但是photo表没有存名字怎么弄

子查询

我们的思路就是通过名字查询user表的id,然后通过user表的id去查询photo的user_id就完成了

sql 复制代码
SELECT * FROM `photo` WHERE `user_id` = (SELECT id FROM `user` WHERE name = '小满')

连表

Mysql的连表分为内连接,外连接,交叉连接

  1. 对于内连接的两个表,驱动表中的记录在被驱动表中找不到匹配的记录,该记录不会加入到最后的结果集,我们上边提到的连接都是所谓的内连接

  2. 对于外连接的两个表,驱动表中的记录即使在被驱动表中没有匹配的记录,也仍然需要加入到结果集。

  3. 交叉连接是指在两张或多张表之间没有任何连接条件的连接。简单来说,交叉连接可以让你查询所有可能的组合。

内连接

sql 复制代码
SELECT * FROM `user`, `photo` WHERE `user`.`id` = `photo`.`user_id`

外连接

左连接

语法规则 LEFT JOIN [连接的表] ON [连接的条件]

并且以第一个表作为驱动表 被驱动表如果没有值则补充null

sql 复制代码
SELECT * FROM `user` LEFT JOIN `table` ON `user`.`id` = `table`.`user_id`

右连接

语法规则 LEFT JOIN [连接的表] ON [连接的条件]

并且以第二个表作为驱动表 被驱动表如果没有值则忽略

sql 复制代码
SELECT * FROM `user` RIGHT JOIN `table` ON `user`.`id` = `table`.`user_id`
相关推荐
好开心332 分钟前
axios的使用
开发语言·前端·javascript·前端框架·html
Domain-zhuo11 分钟前
Git常用命令
前端·git·gitee·github·gitea·gitcode
菜根Sec41 分钟前
XSS跨站脚本攻击漏洞练习
前端·xss
m0_748257181 小时前
Spring Boot FileUpLoad and Interceptor(文件上传和拦截器,Web入门知识)
前端·spring boot·后端
桃园码工1 小时前
15_HTML5 表单属性 --[HTML5 API 学习之旅]
前端·html5·表单属性
百万蹄蹄向前冲2 小时前
2024不一样的VUE3期末考查
前端·javascript·程序员
Anlici2 小时前
three.js建立3D模型展示地球+高亮
前端·数据可视化·canvas
轻口味2 小时前
【每日学点鸿蒙知识】AVCodec、SmartPerf工具、web组件加载、监听键盘的显示隐藏、Asset Store Kit
前端·华为·harmonyos
alikami2 小时前
【若依】用 post 请求传 json 格式的数据下载文件
前端·javascript·json
吃杠碰小鸡3 小时前
lodash常用函数
前端·javascript