基础-事务、视图、存储过程、游标、约束、触发器、数据库安全

内容来自《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语句来管理

如何对数据库升级

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352