查询关键字补充

having过滤

关键字having和where的功能一样的,都是对数据进行筛选,只不过where是用在分组之前的查询筛选,having是用在分组之后的查询筛选。

select 字段 from 表 group by 分组字段 having 条件

distinct去重

distinct关键字用于去掉一模一样的记录,如果数据中有主键,那么肯定无法去重。

select distinct 查询的字段 from 表

order by排序

order by可以对查询出来的数据进行排序。

升序排序

select 字段 from 表 order by 排序字段
# 或者
select 字段 from 表 order by 排序字段 asc

降序排序

select 字段 from 表 order by 排序字段 desc

多字段排序:先按排序字段1升序排序,如果值一样,那么按照排序字段2降序排序。

select 字段 from 表 order by 排序字段1 asc 排序字段2 desc

limit分页

limit关键字用于限制查询出来的记录数。

语法1:只展示m条记录

select 字段 from 表 limit m

语法2:展示m条记录后的n条记录

select 字段 from 表 limit m,n

补充:查询记录最大值

select 字段 from 表 order by 排序字段 desc limit 1

regexp正则

regexp关键字可以使用正则表达式筛选数据。

select 展示的字段 from 表 where 字段 regexp '正则表达式'

多表查询

多表查询的思路有两种:子查询和连表查询

子查询

子查询就是将一条SQL语句的查询结果加括号当做另外一条SQL语句的查询条件;

比如现有学生表与班级表:

  • student(sid,sname,cid(外键))
  • class(cid,cname)

如果想要查询名字为'张三'的学生所在班级,可以先查询'张三'所在的班级id:

select cid from student where sname='张三';

然后把查询的结果当作条件:

select cname from class where cid=(
select cid from student where sname='张三'
);

这种多表查询方式就是子查询。

连表查询

连表查询即两张表或多张表联合查询,连表操作有四个关键字:

  • inner join:只连接两张表中有对应关系的数据
  • left join:以左边的表为基准,展示所有的数据,没有对应项则用NULL填充
  • right join:以右边的表为基准,展示所有的数据,没有对应项则用NULL填充
  • union:两张的表的查询结果拼接在一起输出,前提是两个查询的列数要相同

比如现有学生表与班级表:

  • student(sid,sname,cid(外键))

  • class(cid,cname)

inner join关键字查询

select sname,cname from student inner join class
on student.cid=class.cid;

left join关键字查询

select sname,cname from student left join class
on student.cid=class.cid;

right join关键字查询

select sname,cname from student right join class
on student.cid=class.cid;

union关键字查询

select sname,cname from student left join class
on student.cid=class.cid
union
select sname,cname from student right join class
on student.cid=class.cid;

mysql查询关键字补充与多表查询的更多相关文章

  1. MySQL:记录的增删改查、单表查询、约束条件、多表查询、连表、子查询、pymysql模块、MySQL内置功能

    数据操作 插入数据(记录): 用insert: 补充:插入查询结果: insert into 表名(字段1,字段2,...字段n) select (字段1,字段2,...字段n) where ...; ...

  2. springdata 查询思路:基本的单表查询方法(id,sort) ---->较复杂的单表查询(注解方式,原生sql)--->实现继承类---->复杂的多表联合查询 onetomany

    springdata 查询思路:基本的单表查询方法(id,sort) ---->较复杂的单表查询(注解方式,原生sql)--->实现继承类---->复杂的多表联合查询 onetoma ...

  3. MYSQL 外键 on语句 多表查询

    外键约束 创建外键 --- 每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任 ----主表 CREATE TABLE ClassCharger( id TINYINT PRIMARY KE ...

  4. MySQL多个相同结构的表查询并把结果合并放在一起的语句(union all)

    union all select *,'1' as category from table1001 where price > 10 union all select *,'2' as cate ...

  5. MySQL数据库(4)- 多表查询、可视化工具Navicat的使用、设计模式MVC

    一.多表查询 准备工作:创建两张表,部门表(department).员工表(employee),代码和表格如下: # 创建表 create table department( id int, name ...

  6. MySQL基础(三)多表查询(各种join连接详解)

    Mysql 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到Mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有哪些 ...

  7. Mysql基础(五):多表查询、pymysql模块

    目录 数据库04 /多表查询.pymysql模块 1. 笛卡尔积 2. 连表查询 3. 子查询 4. pymysql模块 数据库04 /多表查询.pymysql模块 1. 笛卡尔积 将两表所有的数据一 ...

  8. mysql学习(十)多表查询

    多表查询时,要给表名起别名,给字段名其别名(当两个表含有重复字段时) select p.name, c.name, pid from products p, cats c;//得到的结果为笛卡尔乘积 ...

  9. MySql语句常用命令整理---多表查询

    首先第一张表还是我们单表查询之前用到t_employee,我们在另外新建一个表t_dept(部门表)建表命令如下: drop table if exists t_dept; CREATE TABLE ...

随机推荐

  1. 9_根轨迹_Part3_分离点/汇合点和根的性质

  2. 前端规范(ES6BEMOOCSSSMACSS)

    前端规范 在实际开发中,由于团队成员编码习惯不一,技术层次不同,开发前定制并遵循一种代码规范能提高代码质量,增加开发效率. Javascript Javascript规范直接参考airbnb: ES6 ...

  3. 如何在 Java 中实现无向图

    基本概念 图的定义 一个图是由点集 \(V=\{v_i\}\) 和 \(V\) 中元素的无序对的一个集合 \(E=\{e_k\}\) 所构成的二元组,记为 \(G=(V,E)\),\(V\) 中的元素 ...

  4. kubectl scale sts

    使用scale 不单单是扩容还可以:1.动态扩展服务,增加承载能力2.如果出现pod异常,可以利用这种方式,增加pod,再删除原来的pod 比如:pod所在宿主机网络或者宿主机死掉注: 但是一旦有某个 ...

  5. Java语言学习day30--8月5日

    ###10String类的其他方法 * A:String类的其他方法 * a: 方法介绍 * int length(): 返回字符串的长度 * String substring(int beginIn ...

  6. 让视障者的网络之路少一些障碍——微软为 Edge 浏览器开发自动图像描述功能并呼吁网页作者补充图片的替换说明

    网页是互联网的组成部分,浏览器是开启互联网大门的钥匙.对于生活在信息时代下的我们而言,每一个人都很难离开网络而生活,其中也包括盲人这一残障群体. 本文的引子是如下一条新闻: IT之家3月18日消息,微 ...

  7. 元素滚动 scroll 系列

    定义 : scroll翻译过来就是滚动的,我们使用scroll系列的相关属性可以动态的得到该元素的大小.滚动距离等. 常用属性 : 需要用到页面滚动事件scroll因为是页面滚动,所以事件源是docu ...

  8. C++ 类成员指针

    C++的类成员指针是一种奇葩的指针. 假设现在我们要表示一个三维的点,现在有两种定义方式: struct point1{ int x, y, z; }; struct point2{ int c[3] ...

  9. pdf.js 预览文件中文内容丢失

    问题: 在.netcore中使用pdf.js,pdf中有部分中文无法显示 在浏览器控制台发现有报错 发现在pdf.view.js中url路径异常,没有指向cmaps文件,于是调整了正确的相对路径 再次 ...

  10. 软件工程-UML各种图总结-精华

    ​ UML(Unified Modeling Language)是一种统一建模语言,为面向对象开发系统的产品进行说明.可视化.和编制文档的一种标准语言.下面将对UML的九种图+包图的基本概念进行介绍以 ...