MYSQLshu数据库学习----查询

查询语句是MYSQL数据库中用到的最多的语句。

查询语句分为几种

  1. 单表查询
  2. 集合函数查询
  3. 连接查询
  4. 子查询
  5. 合并查询
  6. 正则表达式查询

一:单表查询

SELECT 属性 FROM 表名 [WHERE 查询条件][GROUP BY 属性名1 [HAVING 分组条件]][ORDER BY 属性2 [ASC/DESC]][LIMIT];

WHERE 查询条件

查询条件 符号或关键字 例子
比较 =、<、<=、>、>=、!=、<>、!>、!< WHERE ID = 1
指定范围 BETWEEN AND、NOT BETWEEN AND WHERE ID BETWEEN 2 AND 3
指定集合 IN、NOT IN WHERE ID IN(1,2,3)
匹配字符 LIKE、NOT LIKE WHERE ID LIKE ‘1%‘
是否为空值 IS NULL、IS NOT NULL WHERE ID IS NULL
多个条件查询 AND、OR WHERE ID > 1 AND ID <3

这里说下LIKE,如果是WHERE ID LIKE ‘ID‘ 这里LIKE等同与‘=’ 就是WHERE ID = ‘ID‘

‘%‘可以代表任意长度字符串:WHERE ID LIKE ‘I%‘,这里就是匹配以‘I’开头的任意长度字符串

‘_‘可以代表一个字符:WHRER ID LIKE ‘I_‘,这里就是匹配以‘I’开头的2个长度的字符串

GROUP BY 属性1 分组

按照属性分组,属性相同的分为一组,但是显示的时候只会显示出每组的第一条记录,所以单独的分组是没意义的,搭配集合函数使用效果会更好

使用GROUP_CONCAT(属性)函数:会把分组中指定的属性列出来

SELECT GROUP_CONCAT(ID) FROM DEMO GROUP BY SEX;

使用COUNT(属性)函数:会计算分组中指定的属性个数

SELECT COUNT(ID) FROM DEMO GROUP BY SEX;

GROUP BY也可以按照多个属性分组

GROUP BY 属性1,属性2,...:先按照属性1分组,如果属性1中有重复的记录再按照属性2分组,一次类推

HAVING 分组条件

HAVING和WHERE不一样,WHERE条件表达式是作用与表和视图中的,HAVING条件表达式是作用于分组后的数据,用于选择满足条件的组

ORDER BY 属性2

按照属性2对查询结果排序,默认的是升序排序

ASC/DESC

ORDER BY 后面可以设置排序方式

ASC:升序排序,默认就是这个

DESC:降序排序

LIMIT

限制查询结果显示数量

LIMIT 2:只显示查询结果中的前2条记录

LIMIT 2, 4:从查询结果中找到第3条记录开始,显示后面的4条记录,结果集下标从0开始算起。

二:集合函数查询

SELECT [[COUNT()][SUM()][AVG()][MIN()][MAX()]] FROM 表名

COUNT(属性):计算属性记录的个数

SUM(属性):计算属性取值的和

AVG(属性):计算属性取值的平均值

MIN(属性):得到属性取值的最小值

MAX(属性):得到属性取值的最大值

三:连接查询

内连接查询:

假如2个表中有表示相同意义的字段,可以通过内连接查询得到该字段在2个表中的结果集

表1

ID USER PWD

表2

USER TIME

SELECT ID,表1.USER,PWD,TIME FROM 表1,表2 WHERE 表1.USER = 表2.USER

得到结果集类似

ID USER PWD TIME

外连接查询:

分为左连接查询和右连接查询,一般用的比较少,这里不做介绍

四:子查询

子查询语句就是将一个查询语句嵌套进一个查询语句中,内层查询语句结果可以作为外层查询语句的查询条件。

子查询中包含比较运算符和一些关键字IN、NOT IN、ANY、ALL、EXISTS、NOT EXISTS等

IN:内层查询语句结果中包含外层查询语句条件的字段

SELECT * FROM 表1 WHERE 字段1 IN (SELECT 字段1 FROM 表2);

NOT IN和IN相反,这个就不多做描述

ANY:表示满足其中任意一个条件。只要内层查询语句返回的结果中的任何一个,就可以通过该条件来执行外层查询语句

SELECT 字段1 FROM 表1 WHERE 字段1 [[<][=][>][<=][>=][<>][!=]] ANY (SELECT 字段1 FROM 表2);

其实到这里IN关键字和ANY关键字在某种情况下是相同的:

SELECT * FROM 表1 WHERE 字段1 IN (SELECT 字段1 FROM 表2);

SELECT * FROM 表1 WHERE 字段1 = ANY (SELECT 字段1 FROM 表2);

ALL:表示满足其中全部条件。只要满足内层查询语句返回的结果中的全部条件,才可以通过该条件来执行外层查询语句。

SELECT 字段1 FROM 表1 WHERE 字段1 [[<][=][>][<=][>=][<>][!=]] ALL (SELECT 字段1 FROM 表2);

ANY 关键字和ALL关键字的意思是相反的,ANY是只要满足其中一个条件,ALL关键字是满足全部条件。

EXISTS:表示存在,使用EXISTS关键字时,内层查询语句不返回查询记录,而是返回一个真假值,如果为真(true)则执行外层查询语句,如果为假(false)则不执行外层查询语句。

SELECT * FROM 表1 WHERE EXISTS (SELECT * FROM WHERE...);

NOT EXISTS关键字和EXISTS关键字意思相反,这里就不多做描述。

五:正则表达式查询

待续。。。

六:合并查询结果

有时候我们要把两个SELECT语句查询得到的结果合并在一起,我们要用到UNION和UNION ALL关键字

UNION:合并两个SELECT语句查询结果,并且去掉重复的记录。

UNION ALL:合并两个SELECT 语句查询结果。

SELECT ... [[UNION][UNION ALL]] SELECT ...

七:为表和字段取别名

在实际使用的时候有些表的名称和字段的名称都比较长,SELECT语句写出来显的有点臃肿或者不易于阅读,我们可以给表和字段取别名来解决这个问题。

给表取别名:表名 表的别名

给字段取别名:字段名 [AS] 字段的别名

SELECT * FROM TABLE1 T1 WHERE T1.ID = 1;

SELECT ID AS T1ID FROM TABLE1 WHERE T1ID = 1;

时间: 2024-10-07 10:38:07

MYSQLshu数据库学习----查询的相关文章

数据库学习笔记3 基本的查询流 2 select lastname+&#39;,&#39;+firstname as fullname order by lastname+&#39;,&#39;+firstname len() left() stuff() percent , select top(3) with ties

order by子句对查询结果集进行排序 多列和拼接 多列的方式就很简单了 select firstname,lastname from person.person order by lastname,firstname; 这句话表示根据lastname和firstname两列进行排序,并且是先按照lastname进行排序如果有相同的值就按照firstname进行排序. 拼接很有意思,可以写成这个样子 select lastname+','+firstname as fullname from

数据库学习网站和linux学习网站

Oracle ITPub论坛 http://www.itpub.net 著名IT技术论坛.尤以数据库技术闻名. ITPUB论坛的前身应该是建立在 smiling 的 oracle小组,他们搬家前的主页应该是在下面的这个地址吧! http://oracle.myrice.com/ CNOUG论坛 http://www.cnoug.org/ oracle中国用户组,高手云集,讨论Oracle数据库安装.管理.备份.恢复.性能优化: Oracle数据库高级技术HA.VLDB.ORACLE INTERN

浅谈数据库联合查询

http://www.cnblogs.com/Candies/p/4142576.html 本文介绍以下内容: LFET JOIN.RIGHT JOIN.INNER JOIN.UNION.UNION ALL.FULL JOIN等! 测试数据(以下数据未经考证,非真实有效数据,仅作为本次学习的测试数据!) 全国大学排名TOP20 No. 校名 地区 校长 类型 1 北京大学 北京 周其凤 综合 2 清华大学 北京 顾秉林 理工 3 浙江大学 浙江 杨卫 综合 4 复旦大学 上海 杨玉良 综合 5

MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

首先需要回顾一下上一篇文章中的内容:MySQL数据库学习笔记(九)----JDBC的PreparedStatement接口重构增删改查 一.JDBC事务处理: 我们已经知道,事务的概念即:所有的操作要么同时成功,要么同时失败.在MySQL中提供了Commit.Rollback命令进行事务的提交与回滚.实际上在JDBC中也存在事务处理,如果要想进行事务处理的话,则必须按照以下的步骤完成. JDBC中事务处理的步骤: 1.要取消掉JDBC的自动提交:void setAutoCommit(boolea

SQL Server数据库学习总结

经过一段时间的学习,也对数据库有了一些认识,数据库基本是由表,关系,操作组成:对于初学者首先要学的 一图胜"十"言:SQL Server 数据库总结 一个大概的总结 经过一段时间的学习,也对数据库有了一些认识.  数据库基本是由表,关系,操作组成:对于初学者首先要学的:  1.数据库是如何存储数据的  表,约束,触发器  2.数据库是如何操作数据的  insert,update,delete T-sql 函数 存储过程 触发器  3.数据库是如何显示数据的  select SQLSer

数据库学习之--Oracle 架构与MySQL架构对比

数据库学习之--Oracle 架构与MySQL架构对比 一.Oracle .MySQL应用对比 如果要说明三者的区别,首先就要从历史入手. Oracle:中文译作甲骨文,这是一家传奇的公司,有一个传奇的大老板Larry Ellision. Ellision 32岁还一事无成,读了三个大学,没得到一个学位文凭,换了十几家公司,老婆也离他而去.开始创业时只有1200美元,却使得Oracle公司连续12年销售额每年翻一番. Oracle成立于1977年,早期的理论基础,反而来自于一篇IBM的论文<A

MYSQL数据库学习笔记1

MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 修改表 表的增删查改 查询 数据库概念 数据库是一种对大量信息进行管理的一种方法. 数据库系统从结构上看,也是可以分为三层的: 物理层:数据实际如何存储 逻辑层:存储的是什么数据,以及数据间是什么关系 试图层:提供给用户的部分数据 关系数据库 目前关于数据库模型最主流的有两种, 一种叫做关系型数据库,这

MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4085684.html 联系方式:[email protected] [正文] 这一周状态不太好,连续打了几天的点滴,所以博客中断了一个星期,现在继续. 我们在之前的几篇文章中学习了JDBC对数据库的增删改查.其实在实际开发中,一般都是使用第三方工具类,但是只有将之前的基础学习好了,在使用开源工具的

数据库分批查询数据

数据分批查询数据 前段时间由于线上项目的活动问题,发现向第三方系统请求数据的时候,请求的数据量竟然达到了3w多,请求的数据的方式采用Http请求的形式,事先没有想到会有这么多的数据量,所以只能分批去其他系统请求数据,每次请求200条,具体情况为: 在数据库中存在一张表,主要字段有user_id(用户名),count(物品数量),系统要求能够实时更行用户的物品数量,但是保存物品数量的接口不在自己的系统中,所以需要想起他的系统请求数据,主要是每次如何获得用户user_id,又不重复.主要学习的是用数