内容来自《SQL必知必会》,《MySQL技术内幕》
SQL数据类型
事务
常识和数据库基本操作
1.事务处理:
它是一种机制,与文件系统的区别性所在处之一,来管理必须成批执行的SQL操作,来避免中途停止导致数据在数据库中多处不同步的状况,比如新的订单数据加入了存储在了订单列表以后故障了,就没有写入订单物品表,这几个步骤作为一个整体需要操作,事务可以让他错误时可以回退到完全没有做这件的状态
2.事务transaction:一组SQL语句
回退rollback:撤销这组语句
提交commit:
保留点:事务处理中可设置的临时占位符,可以对他发布回退
BEGIN TRANSACTION
...
DELETE ...;
ROLLBACK;
...
SAVEPOINT delete1;
...
if XXXXXX ROLLBACK TRANSACTION delete1;#回滚到保留点之前
COMMIT TRANSACTION
3.可以回退表内容的改变:insert,update,delete
不可以回退表格内容的改变:如create,drop(事务中可以使用但是不起作用)
事务可以把SQL语句按照逻辑来进行分块
START TRANSACTION --开头,直到他被中断或者被commit
DELETE FROM Orders;
ROLLBACK--回退来撤销
一般情况下我们执行SQL语句就会被提交到数据库,叫做隐式提交
这里需要显式提交
使用保留点实现部分提交或者回退,保留点越多越好
SAVEPOINT delete1;--MySQL
...
ROLLBACK TO delete;
事务
事务是访问并更新数据库中数据的一个程序执行单元
符合ACID的特性:
A.原子性Atomicity
事务是一个可分割的执行单位
C.一致性consistency
事务开始和结束,数据库的完整性约束没有被破坏
I.隔离性isolation
也叫并发控制,用锁来实现的
隔离性要求每个读写事务的对象与其他事务的操作对象能够完全隔离开,互相不可见
粒子锁实现并发控制
D.持久性durability
事务一旦commit以后,所有的变化都是永久的,保证了事务的高可靠性
视图
1.概念
视图是虚拟的表,它不包含任何的列和数据,他只是把一个查询的结果打包存储,也就是封装了SELECT语句段
2.为什么需要视图?
免去SQL语句的重写;
用视图代替语句段来简化复杂SQL语句;
使用表的一部分而不用改动数据;
保护数据,仅仅开放部分数据的访问权限;
可以不改动数据而返回数据格式改动以后的结果
3.语句
视图需要唯一命名
可以嵌套,但可能影响性能
静止使用order by
视图不能索引,也不能有关联的触发器
CREATE VIEW ProductCostomers AS
SELETE ...---查询语句
视图可以当成一个表进行使用
可以简化复杂联结,格式化数据,过滤数据,简化复杂数据的结构
存储过程
1.概念
将一条或者多条语句保存起来,可以视为独立的批文件,
简单安全高性能
通过处理封装到一个单元里面,简化复杂操作,还可以实现代码的复用和公用,就是我们的面向对象中的封装性一样
还有安全性,可以跟视图一样对访问数据进行限制
可以提高性能,存储过程是以编译后的形式存储
代码:
EXECUTE AAAAAA('jsab',---接收存储过程名和需要传递给他的参数
'sns'---主键(ID)自动生成
...
)
游标
存储在DBMS服务器上的一个数据库查询语句检索出来的结果集,可以根据需要滚动或者浏览数据
主要用于交互式应用,比如用户需要滚动屏幕上的数据,并对数据浏览或修改
#创建游标
DECLARE CustCursor CURSOR
FOR
SELECT ...
OPEN CURSOR CustCursor;---游标打开
FETCH CustCursor INTO CustRecond;
CLOSE CustCursor
约束
指定数据库插入数据,处理数据的规则
1.主键
主键是一种特殊的约束,保证每行数据的唯一标识
主键的列各行值唯一,不允许空值,不允许修改和更新,不允许重用
创建时在初始值后面添加关键字,PRIMARY KEY
或者在create和alter语句中添加constraint语句:
ADD CONSTRAINT PRIMARY KEY(XXXX)
2.外键
外键是当前表的一列,他的值必须列在另一张表里作为主键
不仅可以强制关联多张表,还可以防止意外删除,也可以删除关联数据,比如启用级联删除就可以
同样是创建时在初始值后面添加关键字references,
cust_id CHAR(10) NOT NULL REFERENCES Customers(cust_id)
或者在create和alter语句中添加语句
ALTER TABLE Orders
ADD CONSTRAINT
FOREIGN KEY (cust_id) REFERENCES Customers (cust_id)
3.唯一约束
约束某一列或几列数据唯一 可以在列上定义UNIQUE约束
4.检查约束
使得任何插入或者更新的数据都会被检查判断能不能插入,不依赖客户端进行判断
quantity IETEGER NOT NULL CHECK (quantity>0),
触发器
他是特殊的存储过程方法,用特定表的trigger关联特定表上的插入、更新或删除操作
应用场景:
1.保持数据一致,原子操作的思想
2.基于当前表的改动需要在其他表中执行一些操作,比如写日志
3.进行验证,并根据需要回退
4.计算列的值或者更新时间戳
数据库安全性保护
1.数据库更删查改权限,比如设定某些表的访问权限,设定修改的权限
2.访问的类型:只读,或者只能访问特定列,这个就可以采取一些措施,比如限定只通过视图或存储过程进行访问
3.其他安全措施,比如数据库服务器的多用户访问,限制账号的访问权限
SQL的grant和 revoke语句来管理