sql 入门经典(第五版) Ryan Stephens 学习笔记 (第六,七,八,九,十章,十一章,十二章)
第六章: 管理数据库事务
事务 是 由第五章 数据操作语言完成的 DML ,是对数据库锁做的一个操作或者修改。
- 所有事务都有开始和结束
- 事务可以被保存和撤销
- 如果事务在中途失败,事务中的任何部分都不会被记录到数据库
事务的特性:
原子性:是指每个事务都是一个不可分割的最小单元,事务要么成功提交,要么失败回滚,不存在半成功半失败的情况。
一致性:跟原子性密切相关,是指事务的执行结果应该使数据库从一种一致性状态到另一种一致性状态。
隔离性:也称为独立性,是指并行事务的修改必须与其他并行事务的修改相互独立。一个事务处理数据,要么是其他事务执行之前的状态,要么是其他事务执行之后的状态,但不能处理其他正在处理的数据。
持久性:事务一旦成功提交,它执行的结果应该能够持久化到数据库中,接下来的其他操作及故障不应该对它的执行结果又任何影响。
控制事务: commit , rollback ,savepoint;
6.1 commit
在操作之前 需要 设置: set autocommit = 0 ; // 否则所有的操作都是 自动提交的
commit: 用于把事务所做的修改保存到数据库,它把上一个commit 或 rollback 命令之后的全部事务都保存到数据库中。
6.2 rollback
用于撤销还没有保存到数据库中的命令,它只能用于撤销上一个commit 或rollback命令之后的事务
6.3 savepoint
保存点,事务过程中的一个逻辑点,可以把事务回退到这个点。
savepoint point_name ;
// update insert delete
rollback to point_name ; // 还原到某个 point
release savepoint point_name; // 删除某个 point
第七章:数据库查询
order by 用法
升序(default)
select * from student order by age , name ; // 根据年龄排序,如果年龄相同根据 name 排序
select * from student order by 1,2,3; // 根据第1,2,3列排序
降序:
select * from student order by age desc , name ; //age 降序,而name 是升序
第八章: 使用操作符对数据进行分类
1、比较操作符
相等/不等于 = <>
大于/小于 > <
大于等于/小于等于 >= <=
2、 逻辑操作符
is null : where name=null;
between : where cost between 10 and 20 ; // 包含 10 和 20
in : where cost in('5','30','39');
like : % : 代表零个,一个,多个字符
_ : 代表一个数字或字符
匹配200开头的值 where salary like '200%'
匹配包含200的值 where salary like '%200%'
匹配第二个三个字符是0 where salary like '_00%';
exists : select cost from tbl where exists (select cost from tbl where cost>100) ;
// 如果cost>100 存在,则显示所有的cost
3、连接操作符
and
or
4、 求反操作符
not between
not like
not in
not exists
not null
5、 算术操作符
第九章: 汇总查询得到的数据
1、 汇总函数:
count : 统计不含NULL记录的字段,它返回一个数值
select count(*) from stu ; 统计stu表中所有行
select count (salary) from stu; 统计stu中所有salary为非空的行数
sum : 返回一组记录中某一个字段的总和。也可以和distinct一起使用 形: sum([distinct] colum_name);
select sum(distinct code) from stu;
avg : 计算一组记录的平局值,与distinct一起使用返回的是 不重复的值得平均值 。 参数必须是数值类型的
select avg(distinct salary) from stu;
max/min 函数: 略
第十章: 数据的排序与分组
在select语句里面 , group by子句在where之后,在order by 之前。
语法结构如下:
select colum_name1 ,colum_name2 from table1 ,table2
where conditions
group by colum1,colum2
order by colum1 ,colum2
先根据salary再根据id排序输出age 和 code
返回不同salary的分组之和
group 与 order by 连在一起使用
select salary , count(*) from stu group by salary order by 2,1 ; // 先按照 salary统计的数量排序,如果数量相同按照 salary 排序
HAVING 子句的用法 (顺序)
select from where
group by
having
order by
select salary , count(*) from stu group by salary having count>2 order by 2,1; // 起到一个判定作用
十一章: 调整数据的外观
1、常用字符函数
concat : concat (colum_name [' ',],column_name2); //只是输出显示改变,表的机构没有变化
example: select concat(name , last_name) full_name from stu; // 连接 姓 和名 , 重新命名为 full_name 输出
translate : translate (character set , value1 ,value2); //mysql : function translate does not exist
repalce : replace (character set , value1 ,value2);
example : select name ,replace (name ,‘h’,'V') from stu; // replace character h in name with V ;
upper/lower : 大小写转换的函数
select name , upper(name) upper_name from stu; // 将name中所有小写字母转换为大写
substr : 获取字符串子串的函数
select name ,substr(name ,1,3) from stu; // 将name中的 前三个字符输出
第十二章: 日期和时间
sql 入门经典(第五版) Ryan Stephens 学习笔记 (第六,七,八,九,十章,十一章,十二章)的更多相关文章
- 《c#入门经典第五版》简介及pdf电子书网盘下载地址(收藏)
<C#入门经典(第5版)>全面讲解C# 2010和.net架构编程知识,为您编写卓越C# 2010程序奠定坚实基础.C#入门经典系列是屡获殊荣的C#名著和超级畅销书.最新版的<C#入 ...
- sql 入门经典(第五版) Ryan Stephens 学习笔记 第四部分:建立复杂的数据库查询/
第十三章: 在查询表里结合表 1.等值结合 : // 选择 tabla_a 和table_b 中id相等的行,输出 他们的id 和name select table_a.id , table_a.na ...
- sql 入门经典(第五版) Ryan Stephens 学习笔记 后续——存储引擎
一.引擎基础 1 查看系统支持的存储引擎 show engines; 2 查看表使用的存储引擎两种方法: a.show table status from database_name where na ...
- sql 入门经典(第五版) Ryan Stephens 学习笔记 第五部分: 性能调整
第十六章: 利用索引改善性能 1. create index 单字段索引: create index index_name on table_name (column_name);唯一索引: ...
- sql 入门经典(第五版) Ryan Stephens 学习笔记 (第一,二,三,,四,五章)
SQL - Structured Query Language (结构化查询语言) 1/ SQL 命令的类型 : 数据定义语言: DDL 数据操作语言: DML 数据查询语言: DQL 数据控制语言 ...
- C#入门经典第五版之变量的更多内容编码题训练
1. 编写一个控制台应用程序,它接收用户输入的一个字符串,将其中的字符以与输入相反的顺序输出. public string ReverseString(string str) { string rev ...
- C#入门经典第五版之变量与表达式编码题训练
问题:编写一个控制台应用程序,要求用户输入4个int值,并显示它们的乘积.提示:可以使用Convert.ToDouble()命令,把用户在控制台上输入的数转换为double, 以此类推,转换成int命 ...
- BOOL运算符号(从C#入门经典第五版中摘录)
只总结自己觉得难的哈: (1) var1=!var2; //(非) (2) var1=var2&var3; //(与) (3)var1=var2|var3; //(或) (4 ...
- 《Python基础教程(第二版)》学习笔记 -> 第六章 抽象
抽象和结构 本章将会介绍如何让将语句组织成函数,还会详细介绍参数(parameter)和作用域(scope)的概念,以及递归的概念及其在程序中的用途. 创建函数 函数可以调用,它执行某种行为,并返回某 ...
随机推荐
- OWIN概述
关于OWIN OWIN defines a standard interface between .NET web servers and web applications. The goal of ...
- C语言动态调用库(转)
转自:http://cloverprince.iteye.com/blog/481309 现有一个主程序用C语言写成.现在要允许第三方开发人员编写扩展的模块,约定第三方开发的模块必须提供一系列已知名称 ...
- Exchange 2013 、Lync 2013、SharePoint 2013
Office办公系列 在企业中广泛应用,目前服务的客户当中,部分客户已经应用到了 Exchange.Lync.CRM.SharePoint等产品,在开发当中多多少少会涉及到集成,为了更好的服务客户.了 ...
- linux常识以及常用命令和参数
linux,it人士众所周知,一款稳定.强大.开源的系统,1973年,unix正式诞生,ritchie等人用c语言写出第一个unix内核,之后经过不后人不断的改进,形成现在linux的各个版本,其中比 ...
- 【DNN】C#中类的一些特性标注
[AttributeUsage] 其实AttributeUsage类就是描述了一个定制特性如和被使用. C# AttributeUsage的使用要明白: AttributeUsage有三个属性,我们可 ...
- Oracle自动统计信息的收集原理及实验
[日期:2014-11-21]来源:Linux社区 作者:stevendbaguo[字体:大 中 小] 从Oracle Database 10g开始,Oracle在建库后就默认创建了一个名为GATH ...
- android XMl 解析神奇xstream 一: 解析android项目中 asset 文件夹 下的 aa.xml 文件
简介 XStream 是一个开源项目,一套简单实用的类库,用于序列化对象与 XML 对象之间的相互转换. 将 XML 文件内容解析为一个对象或将一个对象序列化为 XML 文件. 1.下载工具 xstr ...
- C语言中的指针和内存泄漏
引言 对于任何使用C语言的人,如果问他们C语言的最大烦恼是什么,其中许多人可能会回答说是指针和内存泄漏.这些的确是消耗了开发人员大多数调试时间的事项.指针和内存泄漏对某些开发人员来说似乎令人畏惧,但是 ...
- IOS 网络浅析-(九 NSURLSession代理简介)
从最开始什么都不懂的小白,到到现在略知一二的小孩.我觉得不仅仅是我,大家应该都会注意到代理几乎贯穿着IOS,那么问题来了,我接下来要说什么呢,那就是.标题的内容啦.上篇网络系列的文章我介绍了NSURL ...
- iOS 在制作framework时候对aggregate的配置
# Sets the target folders and the final framework product.# 如果工程名称和Framework的Target名称不一样的话,要自定义FMKNA ...