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)的概念,以及递归的概念及其在程序中的用途. 创建函数 函数可以调用,它执行某种行为,并返回某 ...
随机推荐
- 阿里云主机上安装jdk
今天继续安装jdk到阿里云服务上,大家要看一下阿里云是32位还是64位的,如果是32位下载32位的包,如果是64位的下载64位的包 我的就是64位的,开始我还不知道是怎么区分32/64位的,原来X64 ...
- [.NET] SQL数据分页查询
[.NET] SQL数据分页查询 程序下载 范例下载:点此下载 原始码下载:点此下载 NuGet封装:点此下载 数据查询 开发系统时,使用C#执行SQL查询指令,就可以从SQL数据库里查询所需数据. ...
- virtualenv and virtualenvwrapper on Ubuntu 14.04
In this post I’ll go over my attempt to setup virtual environments for Python development. Most Pyth ...
- CentOS安装Erlang
1.首先要安装编译源码用的编译器gcc&g++,安装方式很简单,先用yum search gcc搜索出包,然后选择适合自己的版本复制全名,用yum intall gcc_XXX来进行安装即可. ...
- REUSE_ALV_GRID_DISPLAY显示ALV,设置可编辑时,与内表数据同步问题
使用function module: REUSE_ALV_GRID_DISPLAY显示ALV,并设置alv某些列可编辑,可是编辑后发现对应的内表数据并没有随之改变.记得需要设置一个参数的值,怎么想也记 ...
- ArcGIS 10 SP5中文版(ArcGIS10补丁5中文版)
下载地址:百度网盘下载地址:http://pan.baidu.com/s/1o7qPGhk 来自:http://zhihu.esrichina.com.cn/?/sort_type-new__day- ...
- 关于ApplicationPoolIdentity
一直以来IIS中的网站默认都是以network service在运行,但是从IIS7开始,默认会以ApplicationPoolIdentity运行. 这个账户比较特殊,是一种虚拟帐户,你无法在计算机 ...
- IOS 杂笔-2(协议)
1.协议的定义 @protocol 协议名称 <NSObject> //方法声明列表 @end; 2.如何遵守协议 (1)类遵守协议 @protocol 类名:父类名 <协议名称1, ...
- Android源码分析之MessageQueue
下面让我们花些时间来看看MessageQueue的具体实现,不过在分析代码之前让我们来理解下在类开头的一大段comments. MessageQueue是比较低层的类,是持有Message(在Loop ...
- iOS开发之网络编程--1、NSURLSession的基本使用
前言:学习NSURLSession的使用之前,先学习一篇关于NSURLSession的好文章<From NSURLConnection to NSURLSession>或者是国内的译文&l ...