node mysql+node+express 表查询及接口建立(6)
一、一张表查询
查询一张表在上一章节说过了,查询全部使用*,具体的就写字段名
'SELECT * FROM company' //查询所有使用*
'SELECT * FROM company WHERE id=?', //查询唯一标识id=x的所有字段
'SELECT name,other FROM company WHERE id=?', //查询唯一标识id下的company表里面的name和other字段
二、多表关联
这里我建立了三个表
表一 company:

表二school:

表三student:

表连接方式:
1、inner join 也叫等值连接,只有满足条件才会显示数据,否则为空
在userSql.js新建newSql对象,属性innerList
首先查询表里面所有数据
newSql:{
detail:'SELECT * FROM student WHERE id=?',
innerList: 'SELECT * FROM company c inner join school s on c.id=s.company_id'// c和s分别是两个表的别名,可以不写。 on 后面是需要满足的条件
}
这样查询出来的是表company的id等于表school的company_id的所有值,显示的是后面表school的字段和值,如果前面表company有字段和school表的字段重复,会发生覆盖行为,如果表company有表school不存在的字段,那么也会显示。列表长度为右表的长度
如果on后面的c.id与s.company_id值不相等,那么显示的数据就是空
注意: 如果想要显示两表的所有字段需要使用nestTables属性 这里left ,right ,inner cross, union都是一样的
在userSql.js中
newSql:{
all:{sql:'SELECT * FROM company c inner join school s on c.id=s.company_id where c.id=?',nestTables:true}
} // where 是选择表company的id的确定值,去掉为全部
这样显示的是全部值,并且格式不符合我们写作习惯

这里把表company和school的字段值分表列了出来,要想写在一个json里面需要改变nestTables的值,当改为'_'隔离符的时候,就可以把所有数据写在一个json里面了

2、left join 取左边表的所有记录 匹配右边表的记录,右表字段覆盖左表相同的字段,如果左表存在右表不存在的字段,依然显示。 列表长度为左表的长度。
如果on 后面的c.id与s.id 不相等,那么左边表company的所有数据会显示出来,右边表为空
在newSql中
leftList: 'SELECT * FROM company c left join school s on c.id=s.id'
3、right join 与left join 正好相反, 不相等时候会把右边表数据显示出来,左边表的数据为空
在newSql中
rightList: 'SELECT * FROM company c right join school s on c.id=s.id',
4、cross join
交叉连接,得到的结果是两个表的乘积; 效果和 inner join 一样
5、union (可以理解为或or的意思)
unionList: 'SELECT * FROM company c left join school s on c.id=s.id union SELECT * FROM company c right join school s on c.id=s.id'
union可以看做是or 如果left join和right join都相等,就都展示出来,如果left join不相等就左连接的第一个表的数据显示,第二张表的为空, right join 右连接的不相等第二张表显示,第一张表不显示。 显示的数据是左连接的返回值和右连接返回值之和。
更多表连接只需要在前面基础上加连接方式和条件 例如:
moreList: 'SELECT * FROM company c left join school s on c.id=s.company_id left join student t on s.id=t.school_id'
node mysql+node+express 表查询及接口建立(6)的更多相关文章
- Vc数据库编程基础MySql数据库的表查询功能
Vc数据库编程基础MySql数据库的表查询功能 一丶简介 不管是任何数据库.都会有查询功能.而且是很重要的功能.上一讲知识简单的讲解了表的查询所有. 那么这次我们需要掌握的则是. 1.使用select ...
- MySQL之多表查询一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习
MySQL之多表查询 阅读目录 一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习 一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都会建 ...
- MySQL之单表查询 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 使用正则表达式查询
MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER B ...
- day15(mysql 的多表查询,事务)
mysql之多表查询 1.合并结果集 作用:合并结果集就是把两个select语句查询的结果连接到一起! /*创建表t1*/ CREATE TABLE t1( a INT PRIMARY KEY , b ...
- mysql数据库优化课程---11、mysql普通多表查询
mysql数据库优化课程---11.mysql普通多表查询 一.总结 一句话总结:select user.username,user.age,class.name,class.ctime from u ...
- Mariadb/MySQL数据库单表查询基本操作及DML语句
Mariadb/MySQL数据库单表查询基本操作及DML语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一数据库及表相关概述 1>.数据库操作 创建数据库: CREATE ...
- day 39 MySQL之多表查询
MySQL之多表查询 阅读目录 一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习 一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都 ...
- day 38 MySQL之单表查询
MySQL之单表查询 阅读目录 一 单表查询的语法 二 关键字的执行优先级(重点) 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER ...
- MySQL的联表查询
MySQL的联表查询 首选:分析查询的字段来自哪些表 进而:确定交集 然后:确定判断的条件 比如:从student表 和 result表 查学号.考试名称.学时.考试日期.考试成绩 表1: 学号 考试 ...
随机推荐
- 微信小程序和微信小程序之间的跳转和传参示例代码附讲解
一:微信小程序跳转 使用限制 需要用户触发跳转 从 2.3.0 版本开始,若用户未点击小程序页面任意位置,则开发者将无法调用此接口自动跳转至其他小程序. 需要用户确认跳转 从 2.3.0 版本开始,在 ...
- 一文理解java对象初始化顺序
例子 Talk is cheap, Show you the code! public class ParentClass { static int parentStaticField = 1; ...
- 基于Groovy搭建Ngrinder脚本调试环境
介绍 最近公司搭建了一套压力测试平台,引用的是开源的项目 Ngrinder,做了二次开发,在脚本管理方面,去掉官方的SVN,引用的是Git,其他就是做了熔断处理等. 对技术一向充满热情的我,必须先来拥 ...
- C#解析深浅拷贝
前言 前面我们学习完了设计模式,在其中我们有了解到原型模式.这里涉及到了克隆自身对象.那么也就是对对象进行拷贝.这里就涉及到了这么一个概念.深浅拷贝.何为深拷贝何为浅拷贝呢?我们一起来看看吧. 浅拷贝 ...
- 使用IDEA开发Spark程序
一.分布式估算圆周率 1.计算原理 假设正方形的面积S等于x²,而正方形的内切圆的面积C等于Pi×(x/2)²,因此圆面积与正方形面积之比C/S就为Pi/4,于是就有Pi=4×C/S. 可以利用计算机 ...
- UI控件拖动失效
问题描述:ui Slider滑块点击时需要特效,直接在滑块上添加OnPointerDown事件与OnPointerUp事件,但是当拖动时会直接触发OnPointerUp事件,而且拖动相关的事件失效 原 ...
- django-Views之装饰器(四)
1.选择支持的请求方式 from django.views.decorators.http import require_http_methods from django.shortcuts impo ...
- Java自动化测试框架-06 - 来给你的测试报告化个妆整个形 - (下)(详细教程)
简介 经过上一次的化妆和整形,有客户提出需求能不能将那个普通会员的套餐再升级一下,再漂亮一点.所以这次咱们就来看看从哪里下刀可以使它变得再漂亮一点点. 上一篇文章修改了一些基本的ReportNG信息, ...
- Elastic search集群新增节点(同一个集群,同一台物理机,基于ES 7.4)
一开始,在电脑上同一个集群新增节点(node)怎么试也不成功,官网guide又语焉不详?集群健康值yellow(表示主分片全部可用,部分复制分片不可用) 最后,在stackoverflow上找到了答案 ...
- 在虚拟机上的关于Apache(阿帕奇)(3)基于IP访问网站
这篇随笔是基于IP访问网站,和后面两篇文章基于域名和基于端口一起练习效果更好 基于IP(记得下载httpd服务) 首先使用nmtui命令为网卡添加多个ip地址 输入命令:nmtui 进入下面这个界 ...