这是Mysql系列第12篇. 环境:mysql5.7.25,cmd命令中进行演示. 本章节非常重要. 子查询 出现在select语句中的select语句,称为子查询或内查询. 外部的select查询语句,称为主查询或外查询. 子查询分类 按结果集的行列数不同分为4种 标量子查询(结果集只有一行一列) 列子查询(结果集只有一列多行) 行子查询(结果集有一行多列) 表子查询(结果集一般为多行多列) 按子查询出现在主查询中的不同位置分 select后面:仅仅支持标量子查询. from后面:支持表子查询…
联合查询 所谓的联合查询就是将满足条件的结果进行拼接在同一张表中. 基本语法: select */字段 from 数据表1 union [all | distinct] select */字段 from 数据表2; 特别说明:使用union联合查询必须有一个前提,每个表读取的字段数必须是一致的 union联合查询默认是去重的. union  all :在数据联合时保存所有数据,示例代码: union  distinct :在数据联合时去重所有重复的数据,示例代码: union的意义:主要用于大数…
一.连接查询(SQL99标准) 1.含义:当要查询的数据来自多张表时要使用连接查询 2.语法: select 查询列表 from 表1 别名 [连接类型] join 表2 别名 on 连接条件 [where 筛选条件] [group by 分组] [having 筛选条件] [order by 排序列表] 注意:SQL99标准支持以下连接方式: #1内连接 #2外连接:左外.右外.全外连接 #3交叉连接(很少用到) 3.内连接: 案例一:查询部门个数>3的城市名和部门个数(分组函数+分组查询)…
mysql表格查询方法: 查询: 1.简单查询 select * from Info --查所有数据select Code,Name from Info --查指定列的数据select Code as '代号',Name as '姓名' from Info --给列指定别名 2.条件查询 select * from Info where Code='p001'select * from Info where Sex='true' and Nation='n001' --多条件并的关系select…
1.子查询简介 其中,所谓的"外层查询"并不是指"查找",指的是所有SQL语句的统称:结构化查询语言(Structured Query Language),简称SQL. : 2.由比较运算符引发的子查询             注意:当子查询返回多个结果的时候,可以用ANY.SOME.ALL修饰,ANY.SOME是等价的:符合返回结果中的一个即可:ALL:符合全部结果.    3.由[NOT]IN/EXISTS引发的子查询      4.使用INSERT...SEL…
多表连接查询 # 返回的是两张表的乘积 SELECT * FROM tb_emp,tb_dept SELECT COUNT(*) FROM tb_emp,tb_dept # 标准写法,每个数据库都能这么写 SELECT * FROM tb_emp CROSS JOIN tb_dept # 内连接 只列出这些连接表中与连接条件相匹配的数据行 SELECT * FROM tb_emp e,tb_dept d WHERE e.NAME = d.NAME SELECT * FROM tb_emp INN…
最近遇到一个测试数据的需求,需要往一个表中插入4个来源的数据. 往orders 表中插入 来自 sql_person cm_user_car_model cm_sp_product_new 部分固定数据以及两个递增的时间数据 对于4的数据很好处理不过是时间处理,以及固定值的递增. 对于1,2,3部分,第一眼想到的是用cross join来去三个表的笛卡尔积,三个表各取一条拼合在一起插入 例如select a.*,b.*,c.*  from (select * from t1 where... l…
函数 Mysql的函数特性没有SQL可移植性强. 大多数情况下支持的函数: 处理文本串的函数: RTrim():处理列值右边的空格 LTrim():处理列值左边的空格   Trim():处理列值的左右两边的空格(中间的不处理)   Upper():文本转大写 Length():返回串的长度 Locate():找出串的一个子串 Lower():文本转小写 ... 算术操作函数: 包含一些常见的数值处理函数如: Abs()取绝对值: Mod()返回除操作的余数: Pi()返回圆周率: Rand();…
参考:http://codingstandards.iteye.com/blog/1344833 上面参考文章中<高性能MySQL>第四章第四节在第三版中我对应章节是第六章第五节 最近分析生产环境慢查询,发现上线很久但是效率不高的查询 MySQL版本5.5.18 SELECT loc.cell_no AS m_cellNo ... FROM bs_loc loc LEFT JOIN st_stock_m m ON loc.cell_no = m.cell_no WHERE loc.zone_n…
当子查询要返回多个行来与外层查询进行比较运算时,可以使用运算符 IN 和 NOT IN.它们会测试某个给定的比较值是否存在于某一组值里.如果外层查询里的行与子查询返回的某一个行相匹配,那么 IN 的结果为真.如果外层查询里的行与子查询返回的所有行都不匹配,那么 NOT IN 的结果为真. 1. 下面两条语句分别使用 IN 和 NOT IN 来查找那些在 absence 表里有缺勤记录的学生和没有缺勤记录的学生: mysql> SELECT * FROM student WHERE student…