一、基础术语

DML(data manipulation language):

如SELECT、UPDATE、INSERT、DELETE,主要用来对数据库里的数据进行操作的语言

DDL(data definition language):

主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,大多在建立表时使用。

DCL(Data Control Language):
数据库控制功能。是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句。默认情况下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL

二、数据库三范式

关系型数据库设计表时为了减小冗余,增强数据的有效性和存储效率,需要遵循一定的规范,这些规范按照严格程度来区分可以分为第一范式(1NF),第二范式(2NF),第三范式(3NF),BC范式(BCNF),第四范式(4NF),第五范式(5NF)等。

数据库范式是数据库设计中必不可少的理论依据,不理解数据库范式就无法设计出搞笑优雅的数据库,甚至依赖混乱,操作经常出错。实际应用中常用的范式有第一范式(1NF),第二范式(2NF)和第三范式(3NF),后面三个范式则用的比较少,这是因为适当的冗余可以增加数据库的查询效率。

第一范式(1NF):属性不可分

第一范式要求数据库表中所有字段都是不可分的原子值。不满足第一范式的数据库,不是关系数据库!

第二范式(2NF):非主属性完全依赖于码

第二范式是在第一范式的基础上更进一步,要求数据库要有主键,其他非主属性完全依赖于主键,而不能只依赖主键中的一部分。即联合主键的情况,如果某一个非主属性只依赖于联合主键中的一个或者部分属性,则不符合第二范式。第二范式隐式要求数据库一张表只保存一种数据,尽量不要把多种数据保存到一张表中。

第三范式(3NF):非主属性之间不存在传递依赖

第三范式是在第二范式的基础上更进一步,要求属性不能依赖于表中的非主属性。第三范式需要确保数据表中的每一列数据都和主键直接相关,而不能间接相关。

三、事务:

事务(Transaction)是并发控制的基本单位。所谓事务,即一系列操作的集合,这些操作要么都不执行,要么全部执行,不允许执行其中一部分,即把一系列操作作为一个整体进行控制。比如银行转账,简化下来至少需要两步操作,1:要从A账户扣除100元,2:给B账户增加100元,这两步操作必须作为一个整体进行控制,假如从A账户扣款成功,给B账户增加金额失败,则事务必须回滚(roolback),即把A账户的扣款返回给A账户。

事务具有四个基本特征(ACID):

Atomic(原子性):
事务中包含的操作被看做一个逻辑单元,这个逻辑单元中的操作要么全部成功,要么全部失败。

Consistency(一致性):
只有合法的数据可以被写入数据库,否则事务应该将其回滚到最初状态。

Isolation(隔离性):
事务允许多个用户对同一个数据进行并发访问,而不破坏数据的正确性和完整性。同时,并行事务的修改必须与其他并行事务的修改相互独立。这表明事务必须是独立的,不应该以任何方式以来于或影响其他事务。

Durability(持久性):
事务结束后,事务处理的结果必须能够得到固化。事务完成之后,它对于系统的影响是永久的,该修改即使出现系统故障也将一直保留,真实的修改了数据库。

如果多个事务同时影响同一条或者同一些数据,将会导致数据混乱或者事务执行失败,因此需要对事务的并发进行控制。隔离级别就是对对事务并发控制的等级。SQL-92标准中定义了四个隔离级别,串行化(SERIALIZABLE)、可重复读(REPEATABLE READ)、读已提交(READ COMMITED)、读未提交(READ UNCOMMITED)

√ 表示可能发生,× 表示不会发生

脏读

不可重复读

幻读

Read uncommitted

Read committed

×

Repeatable read

×

×

Serializable

×

×

×

 
 

假如有两个事务A和B都在对同一个数据库进行操作:

1、如果数据库隔离级别设为Read uncommitted,事务A先操作数据库,修改了一条数据,但未提交事务,此时事务B读数据库,则会读取到事务A未提交的脏数据,即为脏读

2、如果数据库隔离级别设为Read committed,事务A先操作数据库,读取数据data_a,然后事务B讲数据库中对应的数据修改为data_b并提交事务,此时事务A再去读同一条数据,则数据 变为data_b,即不可重复读

3、如果数据库隔离级别设为Repeatable read,事务A先读取某一条件下的一些数据,然后事务B插入一条数据并提交,而这条数据又恰好满足事务A的select条件,此时事务A再去数据库查询该条件下的数据,发现比上一次多了一条,好像出现幻觉一般,称为幻读

4、如果数据库隔离级别设为Serializable,则所有事务都是排着队一条一条执行的,只有上一条事务执行完毕才会开始下一条事务,因而脏读、不可重复读、幻读这些情况都不可能出现。

 
不可重复读与幻读的区别是,不可重复读是因为修改了数据而造成的数据不一致,幻读是因为插入数据造成的数据不一致。
SQL Server 和Oracle默认的隔离级别是Read committed,MySQL数据库默认的隔离级别是Repeatable read
 
四、数据库锁

数据库系统本身的锁机制 :

1、共享锁(Shared Lock) S锁允许多个事务同时对同一数据进行读操作,但是不允许修改数据(与X锁冲突)。

2、更新锁(Update Lock) 更新所也称修改锁,事务在更新某一项数据时需要加U锁,读取该数据项,此时允许其他事务在该项上加S锁,待事务读出并修改后,将U锁升级为X锁,然后写入修改后的数据。

3、排他锁(Exclusive Lock):排他锁是独占锁,一般修改数据时使用,select...for update

4、意向锁(Intent Lock):意向锁是表级锁,说明在资源底层获得共享锁或独占锁的意向。例如,当读取表里的页面时,在请求页共享锁(S锁)之前,事务在表级请求共享意向锁。这样可以防止其他事务随后在表上获取排他锁(X锁),修改整个表格。意向锁可以提高性能,因为数据库引擎仅在表级检查意向锁,确定事务是否能安全地获取该表上的锁,而不需要检查表中的每行或每页上的锁以确定事务是否可以锁定整个表。意向锁有两种用途:防止其他事务以会使较低级别的锁无效的方式修改较高级别资源;提高数据库引擎在较高的粒度级别检测锁冲突的效率。

意向共享锁(IS):表示事务准备给数据行加入共享锁,也就是说一个数据行加共享锁前必须先取得该表的IS锁

意向排他锁(IX):类似上面,表示事务准备给数据行加入排他锁,说明事务在一个数据行加排他锁前必须先取得该表的IX锁。

各种锁的兼容性如下:
 

意向共享(IS)

共享(S)

更新(U)

意向排他(IX)

排他(X)

意向共享(IS)

共享(S)

更新(U)

意向排他(IX)

排他(X)

5、模式锁(Schema Lock):Altert table,改变表结构时使用

6、批量更新锁(Bulk Update Lock):数据库备份恢复

业务级别上的锁机制,hibernate支持有以下两种类型的锁

悲观锁:

对数据被外界修改持保守态度,即认为经常会发生不止一个事务修改同一条数据的情况,因此所有事务对数据修改前都要获取一把锁,用来排斥其他事务对该数据的操作。悲观锁的实现,往往依靠数据库提供的锁机制(也只有数据库层提供的锁机制才能 真正保证数据访问的排他性,否则,即使在本系统中实现了加锁机制,也无法保证外部系 统不会修改数据)。如 select * form user where id=#{id} for update;语句,就会使数据库系统锁定该条记录。

乐观锁:

乐观锁认为多个事务并发修改数据库同一条记录这样的情况是不经常发生的,对事务操作加锁也是非必须的,即对此事持乐观态度。但是同样要保证数据的一致性,乐观锁要使用一个标志位来标示是否存在其他事务同时在操作该条数据,这样的标志位大多是基于数据版本(Version)记录机制实现的。

锁的分类(oracle)

1、按操作划分,可分为DML锁、DDL锁

2、按锁的粒度划分,可分为表级锁、行级锁、页级锁(mysql)

3、按锁级别划分,可分为共享锁、排他锁

4、按加锁方式划分,可分为自动锁、显示锁

5、按使用方式划分,可分为乐观锁、悲观锁

五、其他

视图(View)

数据库视图是一张虚表,逻辑上的表,有时为了区别视图和表,也称表为基本表——Base Table。视图所对应的数据不进行实际存储,不占用物理空间。视图掩码数据库的复杂性,视图把数据库设计的复杂性与用户屏蔽分开,也能起到用户程序与实际数据库表结构解耦的作用。

存储过程

存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。

存储过程与函数的区别:

1.一般情况下,函数实现的功能针对性比较强而存储过程实现的功能要复杂一点。

2..存储过程来说可以返回参数,而函数只能返回值或者表对象。

3.一般将存储过程作为一个独立的部分来执行,而把函数作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以出现在查询语句FROM关键字的后面。

触发器

触发器和存储过程一样,也是一段sql程序。不同的是存储过程通过名字直接调用,而触发器则相当于事件监听器,在某个特定的事件发生时由数据库系统自动调用的。

触发器语法:

create trigger 触发器的名字 on 操作表
befor|after instead of
update|insert|delete
as
SQL语句

在mysql的innoDB引擎下(该引擎下表为事务表),触发器和引起触发器执行的Sql语句具有事务性,如果before类型的触发器执行失败则sql语句不执行,如果sql语句执行失败则after触发器不执行,如果after触发器执行失败则引起触发器执行的sql语句回滚。

游标

游标是一个数据缓冲器,也就是一个内存区域,用来暂时存放受SQL语句影响到的数据。即受影响的数据暂时存放在一张虚表中,这个虚表就是游标。

Orale中游标的类型:

1,隐式游标:在 PL/SQL 程序中执行DML SQL 语句时自动创建隐式游标,名字固定叫sql。数据库中的事物可以回滚,而游标在其中起着非常重要的作用,由于对数据库的操作我们会暂时放在游标中,只要不提交,我们就可以根据游标中内容进行回滚,在一定意义有利于数据库的安全。

2,显式游标:用于从表中取出多行数据,并将多行数据一行一行的单独进行处理.

declare
--1,声明游标
cursor cur is
select * from user;
begin
--2,直接使用,Oracle会自动打开和关闭等操作。
for v_user in cur loop
dbms_output.put_line(v_user.userName);
end loop
end;

转载于:https://www.cnblogs.com/zffenger/p/5778102.html

关系型数据库知识小结相关推荐

  1. Oracle数据库知识小结

    2019独角兽企业重金招聘Python工程师标准>>> 1. 对于日期型数据, 做 *, / 运算不合法 2. 包含空值的数学表达式的值都为空值 3. oracle 中连接字符串使用 ...

  2. mysql 9.0创建数据库_数据库基础学习——MySQL数据库知识小结(9)

    1 MySQL 中的约束 1.1约束类型 • 非空约束(not null) • 唯一性约束(unique) • 主键约束(primary key) PK • 外键约束(foreign key) FK ...

  3. 关系型数据库小结-基础-易理解!

    关系数据库中重要且实用的知识点小结 本篇文章的内容主要是简介关系型数据库的基本概念.关系数据结构&&形式化定义.关系操作.关系的完整性.常用术语.三级模式结构以及模式之间顺序与转换的应 ...

  4. MySQL数据库是非关系_MySQL(数据库)基础知识、关系型数据库yu非关系型数据库、连接认证...

    什么是数据库? 数据库(Database):存储数据的仓库 高效地存储和处理数据的介质(介质主要是两种:磁盘和内存) 数据库系统:DBS(Database System):是一种虚拟系统,将多种内容关 ...

  5. 数据库知识 | 关系型数据库与非关系型数据库小记录

    用一句话来概括数据库作用--数据库用来组织.存储.管理数据.现在信息时代,可以说数据已经成为了一个十分重要的资源,对一家企业来说甚至可以称为最为核心的竞争力,管理好数据资源尤为重要. 文章目录 一.数 ...

  6. MYSQL (关系型数据库管理系统)的基础知识详解

    一.什么是数据库? 数据库,简而言之可视为电子化的文件柜--存储电子文件的处所,用户可以对文件中的数据进行新增.查询.更新.删除等操作 所谓"数据库"是以一定方式储存在一起.能与多 ...

  7. 阿里云新一代关系型数据库 PolarDB 剖析

    本文通过描述关系型数据库发展的背景以及云计算的时代特征,分享了数据库计算力的螺旋式上升的进化理念.并且结合阿里云 RDS 产品的发展路径,阐述了自主研发的新一代云托管关系型数据库 PolarDB 的产 ...

  8. 即将实习的应届毕业生 学习java SpringMVC 数据库 知识总结

    即将实习的应届毕业生 学习java SpringMVC 数据库 知识总结 1.Java语言的优点: 1)Java是纯面向对象语言 2)与平台无关性,一次编译到处运行 3)Java提供了狠多内置类库 4 ...

  9. 肝了三天的四万字MySQL数据库知识总结

    mysql数据库知识梳理总结 即使再小的帆也能远航~ 一. 目录 数据库介绍 数据库安装 SQL概念 DDL DML操作表中的数据 DQL单表查询 数据库备份和还原 DCL 数据库表的约束 表与表之间 ...

最新文章

  1. javascript数据结构与算法---检索算法(二分查找法、计算重复次数)
  2. egret发布的HTML5项目怎么打开,Egret引擎开发指南之发布项目
  3. 【集合框架】JDK1.8源码分析之IdentityHashMap(四)
  4. 《Linux下sed命令的使用》
  5. nhibernate set null to DateTime column
  6. sgi 之vector
  7. 光子 量子 DNA计算机的发展情况,科研萌新关于非冯诺依曼结构计算机的一些知识mewo~~...
  8. 安装secureCRT提示sorry的解决办法
  9. 记一次应用配置的数据库连接被打满问题
  10. Windows 编程[10] - WM_LBUTTONDOWN、WM_LBUTTONUP 和 WM_MOUSEMOVE 消息
  11. 南京航空航天大学2020数据结构课设
  12. es6删除数组某项_es6删除数组元素或者对象元素的方法介绍(代码)
  13. TFBOYS网易云音乐演唱会破纪录 同时在线人数超78万
  14. for in for of区别_这个句型中用介词for还是of?来看看解题技巧
  15. 说透Applet的数字签名之1——Applet及其运行
  16. 成都刘女士的第一场锤子科技发布会 | 现场特写
  17. QT下信号与槽不在同一个线程中如何connect
  18. 数字信号处理matlab版答案,数字信号处理(MATLAB版)
  19. MUI框架学习——了解MUI
  20. rstudio中读取数据_如何在RStudio中预览数据

热门文章

  1. 互联网公司大厂中厂小厂分别指哪些公司?
  2. Evaluate that you caught up with the price cut
  3. python入门——P41魔法方法:构造和析构
  4. 处理机调度的概念、层次
  5. 并行循环和嵌套循环_并行嵌套循环连接–嵌套循环连接和残留谓词的内侧
  6. 了解SQL Server审核
  7. 使用和执行SQL Server Integration Services包的方法
  8. HttpRunnerManager(一)--安装
  9. 截图截取各种右键菜单的方法
  10. Symbol在对象中的作用