数据准备:
创建表:
create table students(
id int unsigned primary key auto_increment not null,
name varchar(20) default '',
age tinyint unsigned default 0,
height decimal(5,2),
gender enum('男','女','人妖','保密'),
cls_id int unsigned default 0,
isdelete bit default 0
);
创建数据:
insert into students values
(0,'韦少',18,180.00,2,1,0),
(0,'小月月',18,180.00,2,2,1),
(0,'彭于晏',29,185.00,1,1,0),
(0,'刘德华',59,175.00,1,2,1),
(0,'芙蓉',38,160.00,2,1,0),
(0,'凤姐',28,150.00,4,2,1),
(0,'王祖贤',18,172.00,2,1,1),
(0,'周杰伦',36,NULL,1,1,0),
(0,'程坤',27,181.00,1,2,0),
(0,'刘亦菲',25,166.00,2,2,0),
(0,'金星',33,162.00,3,3,1),
(0,'静香',12,180.00,2,4,0),
(0,'周杰',34,176.00,2,5,0); 1 查询所有字段:
select * from 表名;
例如 select * from students;
-- 查询students表中的所有信息 2 指定字段查询:
select 列1 , 列2 , ... , 列n from 表名;
例如 select students.id, students.name from students
-- 一般列为 数据库.表.列,数据库和表名可以省略。多表查询的时候表名不能省略 可以通过 as 关键字对表起别名:
例如: select s.id , s.name from students as s;
也可以列起别名:
例如 select id as 编号, name as 姓名 from students; 用as起别名的时候 as可以省略,列名 或 表名 跟别名:
例如: select s.id 编号, s.name 姓名 from students s; 3 消除重复行查询(去重) distinct :
select distinct 列1,列2 from 表名;
例如: select distinct id , name , gender from students;
-- 当查询多个列的时候,会把每条数据作为一个整体去去重复。 4 条件 where
select * from 表名 where 条件;
例如 select * from students where id = 1; where后面支持多种运算符:比较运算符、逻辑运算符、模糊查询、范围查询、空判断 4.1 比较运算符:等于= 等于> 小于< 大于等于>= 小于等于<= 不等于!=或<>
例如:
select * from students where id = 1;
-- 在students表中搜索id是1的。
select * from students where id >5 ;
-- 在students表中查询id比5大的。
select * from students where name != "黄蓉";
-- 查询名字 不是黄蓉的信息。 4.2 逻辑运算符: and or not
select * from students where id > 3 and gender = 0;
-- 在students表中 查询id比3大的 并且 性别是第一个枚举对象的。 4.3 模糊查询: like、rlike
% 表示任意多个任意字符
_ 表示一个任意字符
例如:
select * from students where name like "黄%";
-- 查询姓黄的人 select * from students where name like "黄_";
-- 查询名字是两个字 并且姓黄的人 select * from students where name like "%黄" ;
-- 查询名字中含有黄字的人
select * from students where name rlike "^黄.*";
-- rlike 后面跟正则表达式。
4.4 范围查询:
in 表示在一个非连续的范围内:
select * from students where id in (1,3,8);
-- 查询id 是 1或者3或者8的所有人 select * from students where id between 3 and 8;
-- 查询编号3到8的人 select * from students where id between 3 and 8 and gender =1 ;
-- 查询编号3到8的男生。 空判断 null:
判断是不是空 is null
select * from students where height is null;
-- 查询没有填写身高的人。 判断非空 is not null
select * from students where height is not null;
-- 查询填身高的人的信息 优先级:
优先级由高到低为: 小括号> not > 比较运算符,逻辑运算符
and 比 or先运算,如果同时出现并希望先算or 就要用小括号。 5 排序:
select * from 表名
order by 列1 asc|desc , 列2 asc|desc 1 先按照列1排序,列1相同的时候按照列2排序。
2 默认按照列值从校到大排序列
3 asc从小到大排列,升序
4 desc从大到小排序,降序 例如: select * from students
where gender = 1
order by id desc;
-- 在students表中查询gender是1的 并且按照id的降序排列 select * from students
where isdelete = 0
order by name;
-- 在students表中没有删除的信息 按照name升序进行排序。 6 聚合函数:
1 count(*) 查询总行数
select count(*) from students;
-- 查询students表中一共有多少行数据。
2 max(列) 查询该列的最大值
select max(age) from students;
-- 查询students中age的最大值
3 min(列) 查询该列中最小的值
select min(age) from students;
-- 查询students中age的最小数据
4 sum(列) 查询该列的数值总和
select sum(age) from students;
-- 查询students表中age的总和
5 avg(列) 查询该列的平均值
select avg(age) from students;
-- 查询students列中age的平均值 7 分组
按照字段分组 表示此字段相同的数据会被放到一个组中
分组后 分组的依据列会显示在结果集中,其他列不会显示在结果集中
可以对分组后的数据进行统计,做聚合运算 select 列1 , 列2 ,聚合 ... from 表名 group by 列1,列2 [having 聚合条件] ; 例如:
select gender as 性别 ,count(*)
from students
group by gender;
-- 查询每个性别的总人数 select age as 年龄, count(*) as 数量
from students
group by age;
-- 查询每个年龄的人数 分组后的数据筛选:
select 列1,列2,聚合 ... from 表名
group by 列1,列2,列3...
having 列1,...聚合...
-- having后面的条件运算符与where的相同 例如:
select gender as 性别,count(*)
from students
group by gender
having gender = 1;
-- 查询男生的总人数、 select gender , avg(age) from students group by gender having avg(age)>3;
-- 查询平均年龄大于3的性别有哪些。 对比where 与 having
where 对from 后面 指定的表进行数据筛选,属于对原始数据的筛选
having 是对group by 的结果进行筛选 8 分页 limit :
select * from 表名
limit start , count
-- 略过前start调信息,展示count条信息
-- start可以省略,默认从0开始 事例:
限定每页显示m条数据,当前显示第n页,求总页数。
select * from 表名
limit (n-1)*m , m; 9 连接查询:
mysql支持三种类型的连接查询:内连接、右外连接、左外连接。
select * from 表名
[inner|across|left|right] join 表2 on 表1.列 = 表2.列(条件)
inner|across 代表内连接
left|right 代表外连接 内连接:严格按照条件,两个表必须都严格符合条件。任何一个表不符合条件的都不能进入结果。
select students.* , classes.*
from students
[inner|across] join classes
on students.cls_id = classes.id;
-- 按照班级号相同把两张表内连接,后展示结果
-- 某个class.id 或者students.cls_id 如果在另一个表中没有对应的就不会被查出来 左外连接:右侧表符合条件的数据和左表全部数据拼接,右表找不到跟左表拼接的数据就用null占位。
select students.* , classes.*
from students
left [outer] join classes
on students.cls_id = classes.id;
-- 以class为主表,所有数据都显示,如果students中没有符合条件的 就用null占位 右外连接:左表符合条件的数据和右表全部拼接,左表找不到跟右表拼接的数据用null占位。
select students.* , classes.*
from students
right [outer] join classes
on students.cls_id = classes.id;
-- 以students为主表,所有数据都会显示。如果classes表中没有符合的数据,就用null占位。 10 自关联:
有如下情况:设计省-市-区-县。。。的数据库的时候,
省: province: id ptitle 省编号 、 省名称
市: city: id ctitle proid 市编号 、 市名称 和 所属省的编号
区: area: id atitle citid 区编号 、 区名称 和 所属市的编号 我们发现,一个省有多个市,一个市有多个区和县。这样创建三张表里面结构基本一样。
而且当进行多表操作的时候,难度实际上是非常大的。
所以这种情况经常用到自联结。 我们改变表结构:对于省市区只建一张表:
area: aid 、 atitle 、 pid
编号 名称 上级编号 对于省和直辖市 pid为null 这样我们想关联查询上下级数据的时候,需要用到自关联。
创建表:
create table area(
aid int primary key, -- 自己的编号
atitle varchar(20), -- 自己的名称
pid int -- 上级的编号
); 自关联语句:
select city.*
from area as city
inner join area as province
on city.pid = province.id;
where province.atitle = "山西省"
-- 查询山西省管辖的所有城市 select dis.*
from area as city
inner join area as dis
on dis.pid = city.id
where city.atitle = "广州市";
-- 查询广州市下辖的所有区 11 子查询:
常用关键字:
in (): where 列 in () 括号中存在就符合条件
any|some (): where 列 = any() 括号中任意一个
all(): where 列 = all() 列匹配里面所有
在一个select语句中嵌套另一个select语句 子查询分为:
标量子查询:子查询返回一个数据(一行一列)
列子查询:子查询返回一个列(多行一列)
行子查询:子查询返回一个行(一行多列)
表级子查询:子查询返回一个表(多行多列) 标量子查询:
-- 查询全班大于平均年龄的学生
select *
from students
where students.age > (
select avg(age)
from students
) 列级子查询:
-- 查询班级名为python的所有学生信息
select *
from students
where students.cls_id in (
select id
from classes
where classes.name="python"
); 行级子查询:
-- 查询年龄和身高同时具备全班最大值的学生
select *
from students
where ( age , height ) in (
select max(age), max(height)
from students
); 表级子查询:
-- 查询学生与班级对应信息(表级子查询一定更要写别名)
select t.sname , t.cname from (
select s.name as sname , c.name as cname
from students as s inner join classes as c
on s.cls_id = c.id
)as t ; any\some\all:任意\某个\全部
-- id 大于 任意一个 就是id大于最小值
select classes.name from classes where id > any(select cls_id from students);
-- 等于任意一个 等于 某一个 意义相同 和 in 类似
select classes.name from classes where id = any(select cls_id from students);
select classes.name from classes where id = some(select cls_id from students); -- <> all 和 not in 结果一样,相当于不在里面。
select classes.name from classes where id <> all(select cls_id from students); 很多子查询可以避免,用表连接进行替代。
推荐使用多表 连接,语句清晰,查询速度也更快。

mysql 查询select语句汇总的更多相关文章

  1. Oracle 查询(SELECT)语句(一)

    Ø  简介 本文介绍 Oracle 中查询(SELECT)语句的使用,在 SQL 中 SELECT 语句是相对内容较多的,也是相对比较复杂一点的,所以这里拿出来单独学习. 首先,我们先来理一下思路,我 ...

  2. 【MySQL】SELECT语句 - 查询数据

    第4章 检索数据 文章目录 第4章 检索数据 1.SELECT语句 2.检索单个列 3.检索多个列 4.检索所有列 5.检索不同的行 6.限制结果 7.使用完全限定的表名 8.小结 简单记录 - My ...

  3. MySql:SELECT 语句(三) WHERE 指定查询条件

    1.WHERE 子句条件操作符 包括:> .<.>=.<=.!= .=.BETWEEN ... AND ...(在指定的两个值之间) 示例: 1)select * from s ...

  4. MySQL中SELECT语句简单使用

    最近开始复习mysql,查漏补缺吧. 关于mysql 1.MySQL不区分大小写,但是在MySQL 4.1及之前的版本中,数据库名.表名.列名这些标识符默认是区分大小写的:在之后的版本中默认不区分大小 ...

  5. MySql:SELECT 语句(六) CONCAT() 函数的使用

    一.计算字段 为什么要用计算字段? 1)想要在一个字段中既显示公司地址,又显示公司名称,但是往往这两个都不在一个字段中 2)列数据是大小写混合的,但是报表程序需要把他们全部按大写形式展示出来 3)需要 ...

  6. MySQL数据库select语句的使用方法

    select语句可 以用回车分隔 $sql="select * from article where id=1"和 $sql="select * from article ...

  7. 基于SQL和PYTHON的数据库数据查询select语句

    #xiaodeng#python3#基于SQL和PYTHON的数据库数据查询语句import pymysql #1.基本用法cur.execute("select * from biao&q ...

  8. Microsoft SqlServer2008技术内幕:T-Sql语言基础-读书笔记-单表查询SELECT语句元素

    1.select语句逻辑处理顺序: FORM WHERE GROUP BY HAVING SELECT OVER DISTINCT TOP ORDER BY 总结: 2.FORM子句的表名称应该带上数 ...

  9. MySql数据库常用语句汇总

    第一天1.登陆数据库 mysql -uroot -proot; //-u用户名 -p密码2.启动数据库 net start mysql;3.创建表空间(数据库)create database qy97 ...

随机推荐

  1. Intellij IDEA debug模式下项目启动慢/无法启动的事件解决过程记录

    项目无法启动了 简单的介绍一下事件过程:周一的早上,收到前端同事抛过来的一个任务,说是一个接口无法正常返回数据,于是就让他把参数发过来,我想试着在本地重现一下并且将问题修复掉,这种情况肯定是要通过de ...

  2. FTP站点设置

    0x00前言: 应老师今天教的和题目所需 有了今天的博文 0x01准备: windows server 2008 FTP服务 0x02正文: 1.先安装FTP服务 先打开--服务器管理 点击--添加角 ...

  3. JS时间处理由CST格式转成GMT格式时间

    问题描述:js接收java后台的时间数据时,时间格式的CST时间,而js默认的是GMT时间格式,js 需要对这个时间进行处理才能使用,具体处理方法如function dateToGMT(sDate){ ...

  4. selenium + robotframework的运行原理

    1.点击ride界面启动用例执行时,首先会调用脚本 2.打开pybot脚本查看内容. 3.打开robot包下面的run文件,我们可以看到信息 run文件内容 程序启动的入口, sys.agv所表达的含 ...

  5. freemarker 类型转换

    操作字符串函数  1. substring(start,end)从一个字符串中截取子串  start:截取子串开始的索引,start必须大于等于0,小于等于endend: 截取子串的长度,end必须大 ...

  6. oracle 常用sql字符函数介绍

    常用字符函数介绍 1.ascii 返回与指定的字符对应的十进制数: SQL>select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') ...

  7. 基于bootstrap的表格数据展示

    一.导入bootstrap文件 二.前端html代码 对应的是前台条件查询和js数据获取 js数据获取部分在第四段 三.后台数据 total为集合总数  int类型 rows为前台需要展示的数据集合 ...

  8. Leaflet客户端学习笔记

    Leaflet介绍 Leaflet 是一个为建设交互性好适用于移动设备地图,而开发的现代的.开源的 JavaScript 库.代码仅有 33 KB,但它具有开发在线地图的大部分功能.支持插件扩展, L ...

  9. JavaScript(第二十五天)【事件绑定及深入】

    事件绑定分为两种:一种是传统事件绑定(内联模型,脚本模型),一种是现代事件绑定(DOM2级模型).现代事件绑定在传统绑定上提供了更强大更方便的功能.   一.传统事件绑定的问题 传统事件绑定有内联模型 ...

  10. Build to win--来自小黄衫

    写在前面 首先非常荣幸.非常侥幸能以微弱的优势得到这次小黄衫,感谢各位老师同学的帮助,也谢谢来自<构建之法>团队的小黄衫赞助! 这次能够获得小黄衫,就像汪老师上课说的那样,其实,是一个积累 ...