赞
踩
使用语言 MySQL
使用工具 Navicat Premium 16
代码能力快速提升小方法,看完代码自己敲一遍,十分有用
目录
并且要知道group by是可以去重的,having可以添加分组条件;
in关键字用于父查询匹配子查询返回的多个字段值。
"Subquery returns more than 1 row"这个出错,代表子查询返回了多于1行的结果。
在使用比较运算符时,要求子查询只能返回1条或空的记录。也就是说,在MySQL中,当子查询跟随在<、>、=、>=、<=、!=之后时,子查询的返回结果不能是多条记录;否则将会出现错误。出现了这样的问题时,就需要使用in关键字了,将比较运算符切换为"in"即可;
in的作用是限制条件的筛选范围,而且in后面的子查询可以返回多条记录。
运行结果如下:
通过阅读以上代码,可以看到这条SQL语句包含5层子查询嵌套,其中有两个子查询是in子查询。使用in子查询的条件就是,在开发过程中,如果判断结果集可能为多条数据,则使用in子查询能够避免语句执行错误。
该代码拆分之后就是这样的,条件就是依次把上面的查询填入子查询而已,不过如果是这么多表的查询,不建议使用子查询(会被骂),推荐使用多表联查;
in子查询将结果集中多条数据作为匹配条件,在实际开发过程中,还存在匹配结果集以外的数据的情况。这种查询的实现只需在in关键字前加上表示否定的not即可,也就是not in子查询。
运行结果如下:
这个就是在最近一次开具"血脂、血糖检查"这项检查的科室以外科室看过病的所有病人;
这个就是在最近一次开具"血脂、血糖检查"这项检查的科室看过病的病人之外的所有输出出来。因此,在编写SQL语句时一定要注意语句的逻辑。
我们使用SQL语句创建数据库或数据表时使用了exists关键字,用它来判断数据库或数据表是否存在,以决定是否执行创建数据库或数据表的操作。实际上exists和not exists关键字也可以用于子查询。
在执行create或drop语句前,exists语句判断该数据库对象是否已经存在,exists的返回值是true或false,根据exists的返回值决定是否执行数据库操作语句。exists的另一种是在where语句作为子查询使用,语法格式如下:
exists在where子句中作为子查询使用时,若子查询的查询结果中有数据,则exists子查询的结果为true,其外层查询语句会被执行。若子查询的查询结果中没有数据,则exists子查询的结果为false,其外层查询语句不会被执行。
运行结果
在以上示例中,使用exists子查询来判断病人是否做过"血脂、血糖检查",若有,则exists子句返回true。在exists子句返回true后,外层查询继续执行。其中,病人的年龄在表中并没有直接给出,需要通过时间日期函数和算术函数计算得到。
运行结果
这个不会进行查询,只会判断李思雨是否有检查过凝血五项,如果没有检查过就查询后添加数据;
当一个查询时另一个查询的条件时,被称为子查询。子查询可以使几个简单的查询语句构成功能强大的符合查询语句;
在select子句中进行子查询的语法格式如下:
在from子句中进行子查询的语法格式如下:
在from子句中的子查询必须加as别名,别名可以任意取,没有特殊的要求;
子查询的输出结果通常作为其外层子查询的数据源或用于数据判断匹配,而不能作为最外层selec子句的输出字段。
实现同一个需求可以使用不同的方式,但是不同实现方式的效率是不同的。在数据量比较小的条件下,这种效率上的差距还不是很明显,但是当数据量很大,并且对执行时间要求较高时,差距会非常明显。因此,良好的开发习惯是代码调试成功后,进一步思考是否有更好的解决方法。
多表联查在 MySQL 中通常通过使用 JOIN 子句来实现。有几种类型的 JOIN,包括 INNER JOIN、LEFT JOIN、RIGHT JOIN 和 FULL JOIN。下面是一个简单的例子,展示了如何在 MySQL 中执行多表联查:
假设你有三个表:patient、prescription 和 checkitem。patient 表包含患者信息,prescription 表包含处方信息,checkitem 表包含检查项目信息。
运行结果
或者可以不写连接,直接在表列表写需要的表,然后在where中写上多表联查的条件即可 ;
LEFT JOIN 语法如下:
SELECT 列列表
FROM 左表
LEFT JOIN 右表 ON 左表.列 = 右表.列;
RIGHT JOIN 语法如下:
SELECT 列列表
FROM 左表
RIGHT JOIN 右表 ON 左表.列 = 右表.列;
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。