2017年06月30号 星期五 多云 空气质量:中度污染
内容:MySQL第三节课
一、delete 和 truncate的区别
01.delete
begin (开启事务)
select * from grade;(查询年级表中所有的数据) delete from grade; (删除年级表中所有的数据)select * from grade;(查询年级表中所有的数据,没有数据) rollback; (事务回滚)select * from grade;(查询年级表中所有的数据,删除的数据恢复) commit (提交事务)02.truncate
begin (开启事务)
select * from grade;(查询年级表中所有的数据) truncate table grade; (删除年级表中所有的数据)select * from grade;(查询年级表中所有的数据,没有数据) rollback; (事务回滚)select * from grade;(查询年级表中所有的数据,没有数据) commit (提交事务)03.区别:
001.delete后面可以拼接where条件,删除指定的行! truncate只能删除表中所有的数据!不能有where!002.delete可以回滚,数据库可以恢复!
truncate 不能事务混滚,数据不可以恢复!003.truncate执行效率高!
二.事务的特性 ACID
01.事务:一条或者多条sql语句的集合!
02.事务的特性
001.原子性 (Atomicity):在事务中的操作,要么都执行,要么都不执行!
002.一致性(Consistency):事务必须保证数据库从一个一致性的状态变成另一个一致性的状态!
003.隔离性(Isolation):每个事务之间互不干扰!哪怕是并发执行也不干扰!
004.持久性(Durability):事务一旦被改变,那么对数据库中数据的影响是永久性的!
三.查询
01.将查询结果保存到 新表中
create table newStudent
(select stuName,address from student)02.使用 具体的列 代替 *
select * from student;
select stuName,age ,address from student;
03.使用别名
SELECT gradeID AS 年级编号,gradeName '年级 名称' FROM grade;
*格式:
001. 列名 AS 别名002. 列名 别名003. 如果别名中有特殊符号,必须把 别名用 单引号 引起来!04.查询年级表中 id不等于1的数据 <> !=
SELECT gradeID,gradeName
FROM gradeWHERE gradeid <> 105.合并
001.+ :
必须是相同的数据类型,而且是能转换成2进制的数据!
如果有一个列是null 整体返回null!002.我们通常使用 concat来做合并
SELECT CONCAT(loginPwd,',',studentNAME) AS 合并列 FROM STUDENT
06.null
001.标识 空值
002.不是0,也不是空串" " 003.只能出现在定义 允许为null的字段 004.只能使用is null 或者is not null 进行比较!使用is null 的时候 要确保 查询的列 可以为空!
SELECT * FROM student
WHERE loginPwd IS NULL07.聚合函数
001.概念:SQL基本函数,聚合函数对一组值执行计算,并返回单个值。除了 COUNT 以外,聚合函数都会忽略空值。
聚合函数经常与 SELECT 语句的 GROUP BY 子句一起使用。
002.具体函数及应用
count() 查询某个字段的行数
max()查询某个字段的最大值min()查询某个字段的最小值sum()查询某个字段的和avg()查询某个字段的平均值-- 查询成绩表的总成绩
SELECT SUM(studentResult) FROM result;-- 查询成绩的平均值SELECT AVG(studentResult) FROM result;-- 查询成绩的最高分SELECT MAX(studentResult) FROM result;-- 查询成绩的最低分SELECT MIN(studentResult) FROM result;-- 查询有成绩的总数SELECT COUNT(studentResult) FROM result;08.常用的字符串函数
001.-- concat(str1,str2...strN) 连接字符串
SELECT CONCAT('h','el','lo') FROM DUAL;
002.-- insert(str,begin,length,newStr) 替换字符串
-- str初始的字符串 begin 开始的位置 从1开始
-- length 替换长度 newStr替换的字符串SELECT INSERT('hello',2,3,'55555') FROM DUAL;
003.-- subString(str,begin,length) 截取字符串
SELECT SUBSTRING('hello',2,3) FROM DUAL;
004.-- lower(str)转换成小写
005.-- upper(str)转换成大写09.dual
001.我们称之为 伪表!
1. dual 确实是一张表.是一张只有一个字段,一行记录的表.
2.习惯上,我们称之为'伪表'.因为他不存储主题数据.3. 他的存在,是为了操作上的方便.因为select 都是要有特定对象的.如:select * from mytable ;select * from myview;等等.但如果我们不需要从具体的表来取得表中数据,而是单纯地为了得到一些我们想得到的信息,
并要通过select 完成时,就要借助一个对象,这个对象,就是dual;
002.在mysql中是一个摆设
select 9*9;
select 9*9 from dual;select * from dual; 报错
003.oracle中 必须使用 from dual;
select 9*9 from dual; 正确的select 9*9 ; 错误004.dual是一个只有一行一列的表!只能查询! 不能对 dual进行增删改!
10.和并列
001.建立表testa
DROP TABLE IF EXISTS `testa`;
CREATE TABLE `testa` (
`name` varchar(20) DEFAULT NULL, `subject` varchar(20) DEFAULT NULL, `score` double DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8;insert into `testa`(`name`,`subject`,`score`) values ('张三','语文',80),('李四','语文',90),('王五','语文',70),('张三','数学',60),('李四','数学',98),('王五','数学',100);
002.需要成绩和科目 在一列 显示 根据name分组
SELECT
`name` AS 姓名,GROUP_CONCAT(`subject`,':',score) AS 成绩FROM testaGROUP BY `name`;11.常用的日期和时间函数
-- 001.获取 年月日
SELECT CURDATE() FROM DUAL;-- 002.获取 时分秒
SELECT CURTIME() FROM DUAL;-- 003.获取 年月日 时分秒
SELECT NOW() FROM DUAL;-- 004.获取年份
SELECT YEAR(NOW()) FROM DUAL; SELECT YEAR(CURDATE()) FROM DUAL;-- 005.获取小时
SELECT HOUR(NOW()) FROM DUAL; SELECT HOUR(CURTIME()) FROM DUAL;-- 006.获取分钟
SELECT MINUTE(NOW()) FROM DUAL; SELECT MINUTE(CURTIME()) FROM DUAL;-- 007.获取当前日期是本年的第几周
SELECT WEEK(NOW()) FROM DUAL;-- 008.获取两个日期之间的天数
SELECT DATEDIFF(NOW(),'2015-06-01') FROM DUAL;-- 009.获取给定日期之后的某个日期
SELECT ADDDATE(NOW(),30) FROM DUAL;12.天花板函数
-- 001.返回大于或者等于指定表达式的最小整数
SELECT CEIL(3.0) FROM DUAL;
SELECT CEIL(3.1) FROM DUAL;-- 002.返回小于或者等于指定表达式的最大整数
SELECT FLOOR(3.9) FROM DUAL;
SELECT FLOOR(4.0) FROM DUAL;-- 003.返回0-1之间的随机数
SELECT RAND() FROM DUAL;-- 004.四舍五入
SELECT ROUND(2.499) FROM DUAL;
SELECT ROUND(2.501) FROM DUAL;13.ORDER BY 排序
ORDER BY 语句用于对结果集进行排序。
ASC:升序(默认),DESC:降序。ORDER BY 语句默认按照升序对记录进行排序。如果您希望按照降序对记录进行排序,可以使用 DESC 关键字。001. asc:默认值!升序 desc:降序
002.应用
-- 查询所有年级编号为1的学员信息,按学号升序排序
SELECT * FROM studentWHERE GradeID=1ORDER BY Studentno ASC;14.limit 分页显示
001.用法
-- 分页 使用 limit begin,pageSize
-- begin 从哪一条数据开始 (当前页码-1)*pageSize-- pageSize 每页显示的数量002.应用
-- 显示前4条记录
SELECT * FROM studentWHERE GradeID=1ORDER BY Studentno ASCLIMIT 0,4;-- 每页4条,显示第2页,即从第5条记录开始显示4条数据
SELECT * FROM studentWHERE GradeID=1ORDER BY Studentno ASCLIMIT 4,4003.图解
15.子查询
-- 子查询:把一个查询的结果 当成另一个查询的 字段,条件或者表!
SELECT studentName FROM student
-- 只能通过student 表 查询出 学生对应的 年级名称
-- 001. 先查询出 学生 武松 对应的 年级编号
SELECT GradeID FROM student WHERE studentName='武松'-- 002.根据年级编号 取 年级名称
SELECT gradeName FROM grade WHERE GradeID=???SELECT gradeName FROM grade WHERE GradeID
=(SELECT GradeID FROM student WHERE studentName='武松')
四、作业
看完mysql
五、老师辛苦了!