MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)

上传人:汽*** 文档编号:498228386 上传时间:2022-11-18 格式:DOC 页数:8 大小:22KB
返回 下载 相关 举报
MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)_第1页
第1页 / 共8页
MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)_第2页
第2页 / 共8页
MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)_第3页
第3页 / 共8页
MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)_第4页
第4页 / 共8页
MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)》由会员分享,可在线阅读,更多相关《MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)(8页珍藏版)》请在金锄头文库上搜索。

1、 欢迎阅读本文档,希望本文档能对您有所帮助!MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)五、数据查询语言(DQL) (重中之重)完整语法格式:select 表达式1|字段,.from 表名 where 条件group by 列名having 条件order by 列名 asc|desclimit 位置,数量lt;1普通查询select 查询表达式;/最简单的sql语句,是一个函数select database(); select version(); select now();lt;2条件查询where 条件表达式,支持运算符和函数MySQL支持的运算符:=、!=、=

2、、 lt; 、 lt;= 、 lt;and、or、notis null、is not nullbetween.and. 区间查询 多少到多少之间in(set);like 通配符和占位符: % _ (模糊查询)%:表示0个或者多个字符_:表示占位一个- 查询所有的老师信息select * from teacher;- 查询id大于2的老师信息select * from teacher where id2;- 查询姓名为空的老师信息 在数据库中null永远的不等于null,那么怎么去判断null值呢? 通过is null、is not nullselect * from teacher where

3、 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 sallt;=10000;select * from teacher where sal between 2000 and 1000

4、0; # 这种方式等同于上面这种方式- 查询姓名中有拿字的老师信息select * from teacher where name like %拿%;- 查询姓名是三个字的select * from teacher where name like _;- 查询姓小的老师信息select * from teacher where name like 小%;- 查询名字中含有下划线的老师select * from teacher where name like %_%;lt;3分组查询group by 列名 having 条件一般情况分组查询结合聚合函数一起使用(max()、min()、sum()

5、、avg()、count()- 查询每个部门的平均薪资select dname,avg(sal) from teacher group by dname- 查询部门平均薪资大于5000的部门select dname,avg(sal) from teacher group by dname having avg(sal)5000select dname,avg(sal) asal from teacher group by dname having asal5000记住:分组的正确使用方式,group by 后面没有出现的列名不能出现在select 和from的中间,虽然不报错但是不是分组的正确

6、使用方式。 聚合函数中出现的列名group by后面没有无所谓。lt;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进行升序排序,利用默认排序lt;5限制结果集数量的查询(分页)编号 商品名称 商品价格 操作1 大拿娃娃 100.0 删除

7、 修改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 *

8、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事务默认自动开启的。在MyS

9、QK数据库中只有使用Innodb数据库引擎的数据表或库才支持事务。通过事务来管理 insert、update、delete语句事务必须满足4个条件(ACID):原子性:要么全部完成,要么全部不完成,不会结束在中间的某个环节。在执行的过程中一旦出现错误/异常,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。一致性:事务处理前后数据保持一致。隔离性:事务处理必须是独立的彼此隔离持久性:事务对数据的修改被永久保存lt;1为什么使用事务银行转账:老王给大拿转账30000元事务广泛使用:订单系统,银行系统等.lt;2MySQL事务控制commit(提交)、rollback

10、(回滚)、savepoint(事务节点)lt;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;/事务提交 欢迎阅读本文档,希望本文档能对您有所帮助!

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 行业资料 > 国内外标准规范

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号