MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)
五、数据查询语言(DQL) (重中之重)
完整语法格式:
select 表达式1|字段,....
[from 表名 where 条件]
[group by 列名]
[having 条件]
[order by 列名 [asc|desc]]
[limit 位置,数量]
<1>普通查询
select 查询表达式;//最简单的sql语句,是一个函数
select database(); select version(); select now();
<2>条件查询
where 条件表达式,支持运算符和函数
MySQL支持的运算符:
=、!=、>、>=、 < 、 <= 、 <>
and、or、not
is null、is not null
between...and..... 区间查询 多少到多少之间
in(set);
like 通配符和占位符: % _ (模糊查询)
%:表示0个或者多个字符
_:表示占位一个
-- 查询所有的老师信息
select * from teacher;
-- 查询id大于2的老师信息
select * from teacher where id>2;
-- 查询姓名为空的老师信息 在数据库中null永远的不等于null,那么怎么去判断null值呢? 通过is null、is not null
select * from teacher where name is not null
-- 查询id为1 并且 姓名是“xiaosi”的老师信息
select * from teacher where id=1 and name ='xiaosi';
-- 查询id为1 或者 姓名是“xiaosi”的老师信息
select * from teacher where id=1 or name ='xiaosi';
-- 查询薪水在2000到10000之间的老师信息
select * from teacher where sal >=2000 and sal<=10000;
select * from teacher where sal between 2000 and 10000; # 这种方式等同于上面这种方式
-- 查询姓名中有“拿”字的老师信息
select * from teacher where name like '%拿%';
-- 查询姓名是三个字的
select * from teacher where name like '___';
-- 查询姓“小”的老师信息
select * from teacher where name like '小%';
-- 查询名字中含有下划线的老师
select * from teacher where name like '%\_%';
<3>分组查询
[group by 列名] [having 条件]
一般情况分组查询结合聚合函数一起使用
(max()、min()、sum()、avg()、count())
-- 查询每个部门的平均薪资
select dname,avg(sal) from teacher group by dname
-- 查询部门平均薪资大于5000的部门
select dname,avg(sal) from teacher group by dname having avg(sal)>5000
select dname,avg(sal) asal from teacher group by dname having asal>5000
记住:分组的正确使用方式,group by 后面没有出现的列名不能出现在select 和from的中间,虽然不报错但是不是分组的正确使用方式。 聚合函数中出现的列名group by后面没有无所谓。
<4>排序查询
语法格式:order by 列名 asc|desc 默认升序(asc)
-- 查询老师信息,要求根据薪资从大到小进行排序
select * from teacher order by sal desc 根据sal进行降序排序
select * from teacher order by sal asc 根据sal进行升序排序
select * from teacher order by sal 根据sal进行升序排序,利用默认排序
<5>限制结果集数量的查询(分页)
编号 商品名称 商品价格 操作
1 大拿娃娃 100.0 删除 修改
2 吕吕娃娃 200.0 删除 修改
3 丛浩娃娃 350.0 删除 修改
.....................
首页 上一页 1 2 3 4 5 下一页 尾页
语法格式:
limit n条数; ------从第一条开始取n条数据。(了解)
语法格式:
limit start开始下标索引,count条数; ---从起始位置start取count条数据(起始位置从0开始) 推荐使用
分页(每页显示2条数据)
第一页: select * from teacher limit 0,2;
第二页: select * from teacher limit 2,2;
第三页: select * from teacher limit 4,2;
第四页: select * from teacher limit 6,2;
第五页: select * from teacher limit 8,2;
分页公式:
开始下标索引(起始位置) = (当前页-1)*每页显示条数;
扩展:
别名
select * from teacher; -- 查询表中所有字段记录
select name,sal,dname from teacher; -- 查询表中指定字段记录
-- 给查询的字段设置别名 同时也可以给表设置别名 通过as 关键字实现别名
select name as '姓名',sal '薪资',dname '部门名称' from teacher
六、事务控制语言(TCL)
MySQL事务默认自动开启的。
在MySQK数据库中只有使用Innodb数据库引擎的数据表或库才支持事务。
通过事务来管理 insert、update、delete语句
事务必须满足4个条件(ACID):
原子性:要么全部完成,要么全部不完成,,不会结束在中间的某个环节。在执行的过程中一旦
出现错误/异常,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
一致性:事务处理前后数据保持一致。
隔离性:事务处理必须是独立的彼此隔离
持久性:事务对数据的修改被永久保存
<1>为什么使用事务
银行转账:老王给大拿转账30000元
事务广泛使用:订单系统,银行系统等.....
<2>MySQL事务控制
commit(提交)、rollback(回滚)、savepoint(事务节点)
<3>实战操作
create table student(
id int,
name varchar(32),
age int,
money double
);
insert into student values (1,'老王',18,60000);
语法:
set autocommit = false|true;//设置事务的提交方式
rollback;//事务回滚
commit;//事务提交
savepoint 节点名称;//设置回滚的节点
rollback to 节点名称;//回滚到具体的某个节点。
例如:
set autocommit = false;//设置事务手动提交
delete from student where id=1;//删除id为1 的信息
rollback;//事务回滚
commit;//事务提交
update student set money = money-30000 where id=1;
savepoint t1;//设置事务节点
update student set money = money-20000 where id=1;
rollback to t1;//回滚到t1节点位置
commit;////事务提交

MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)的更多相关文章
- Mysql数据库下InnoDB数据引擎下的事务详解
一.什么是数据库事务? 数据库事务( transaction)是访问并可能操作各种数据项的一个数据库操作序列,这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位.事务由事务开始与事务结束之 ...
- MySQL之数据查询语言(DQL)
数据查询语言DQL基本结构是由SELECT子句,FROM子句,WHERE子句组成的查询块: SELECT <字段> FROM <表名> WHERE <查询条件> - ...
- MySQL数据库笔记二:数据类型及数据库操作
三.MySQL数据库数据类型 MySQL数据库中支持多种数据类型:数值型.字符型.日期型 常用的数据类型: 1.整型 int:整形,存储整数 int(M):M表示预期值.与存储大小和数值的范围无关. ...
- EF 连接MySQL 数据库 保存中文数据后乱码问题
EF 连接MySQL 数据库 保存中文数据后乱码问题 采用Code First 生成的数据库,MySQL数据库中,生成的表的编码格式为***** 发现这个问题后,全部手动改成UTF8(图是另一个表的 ...
- 学习资料 数据查询语言DQL
数据查询语言DQL介绍及其应用: 查询是SQL语言的核心,SQL语言只提供唯一一个用于数据库查询的语句,即SELECT语句.用于表达SQL查询的SELECT语句是功能最强也是最复杂的SQL语句,它提供 ...
- mysql数据库千万级别数据的查询优化和分页测试
原文地址:原创 mysql数据库千万级别数据的查询优化和分页测试作者:于堡舰 本文为本人最近利用几个小时才分析总结出的原创文章,希望大家转载,但是要注明出处 http://blog.sina.com. ...
- MySQL数据库表的数据插入、修改、删除、查询操作及实例应用
一.MySQL数据库表的数据插入.修改.删除和查询 CREATE DATABASE db0504; USE db0504; CREATE TABLE student ( sno ) NOT NULL ...
- MySql学习笔记三
MySql学习笔记三 4.DML(数据操作语言) 插入:insert 修改:update 删除:delete 4.1.插入语句 语法: insert into 表名 (列名1,列名2,...) val ...
- mysql数据库笔记0
mysql数据库笔记0 一次性添加多行数据 例如: INSERT INTO students (class_id, name, gender, score) VALUES (1, '大宝', 'M', ...
随机推荐
- python 实例方法、类方法和静态方法
#!/usr/bin/env python3.6 #-*- coding:utf-8 -*- # class Person(object): city = 'Beijing' def __init__ ...
- LAMP之Apache调优
一.环境的搭建 实验环境: 操作系统:Centos 7.4 [root@xuegod70 ~]# ls apr-1.6.3.tar.gz apr-util-1.6.1.tar.bz2 httpd-2. ...
- Linux 查看CPU和内存的使用情况
Linux 查看CPU和内存的使用情况 如何查看Linux机器的CPU和内存的使用情况. 可以通过如下方式: 1.查看CPU和内存的实时使用情况 使用如下命令: top 命令执行后,效果如下(资源的使 ...
- 建立Maven工程时出错,Failure to transfer
建立Maven工程时出错,Failure to transfer com.thoughtworks.xstream:xstream:jar:1.3.1 Failure to transfer com. ...
- python中学习K-Means和图片压缩
python中学习K-Means和图片压缩 大家在学习python中,经常会使用到K-Means和图片压缩的,我们在此给大家分享一下K-Means和图片压缩的方法和原理,喜欢的朋友收藏一下吧. 通俗的 ...
- uni-app 实现热更新
前端打包 app 即把写好的静态资源文件套壳打包成 app ,而热更新即下载并替换 app 内部的静态资源文件,实现 app 的版本升级. 在uni-app 中,我们是如何实现热更新的呢?下面来看代码 ...
- 【CSS】我的颜色到底听谁的?—— css的层叠性
我们之前学了很多个选择器,都可以帮我们定位到具体标签上,然后我们在设置样式.但这也不可避免会产生一个问题:如果多个选择器同时指向同一个标签,那么到底该听谁的??? css一定有自己的机制来处理这个问题 ...
- IDEA 2019.2.2破解激活方法(激活到2089年8月,亲测有效)
本来笔者这边是有个正版激活码可以使用的,但是,2019.9月3号的时候,一些小伙伴反映这个注册码已经失效了,于是拿着自己的 IDEA, 赶快测试了一下,果不其然,已然是不能用了. 好在,笔者又找到了新 ...
- Linux通配符知识深度实践详解
注意:linux通配符和三剑客(grep.awk.sed)正则表达式是不一样的,因此,代表的意义也有较大的区别. 通配符一般用户命令行bash环境,而Linux正则表达式用于grep.sed.awk场 ...
- [转帖]Nginx 容器教程
Nginx 容器教程 http://www.ruanyifeng.com/blog/2018/02/nginx-docker.html 里面有证书. 作者: 阮一峰 日期: 2018年2月27日 感谢 ...