基本概念
数据库:存放与管理数据的仓库,是逻辑上相关的数据的集合。优点有:减少数据冗余度、具有较高的独立性、便于数据共享。
数据库系统:由数据库及其管理软件组成的系统。
SQL:Structured Query Language,结构化查询语言,用来访问关系型数据库。
表:等同于二维数组,每一列是数据属性,每一行是数据内容。
字段:表中的列也叫字段。字段有自己的名字与属性。
索引:是单独的数据库结构,用来加速数据检索。
视图:将查询的结果以虚拟表的形式存储,用于保护数据安全性。
存储过程:能够完成特定功能的SQL语句的集合,类似于高级语言中的函数。
属性
规范化
范式:Normal Form。
1NF:表的每一字段都是不可分割的基本数据项。
2NF:首先要满足1NF,然后要求数据库表中的每个非主关键字段都完全依赖于主关键字段。
3NF:首先要满足2NF,然后要求不存在非关键字段对任一候选关键字段的传递函数依赖。
一般说来,数据库只需满足第三范式(3NF)就行了。
索引
是单独的数据库结构,用来加速数据检索。
缺点:1.占用额外存储空间;2.对表中数据修改时,索引也要动态维护,效率降低。
聚集索引:根据数据行的键值排序和存储。
非聚集索引:不修改原表中数据项的位置。
存储过程与触发器
数据库中的存储过程类似于高级语言中的函数,是能够完成特定功能的语句的集合。优点:代码重用、可传参数。
create procedure fun1 //根据学生编号查询学生信息
@x int
as
select * from Student where stu_id=@x
调用方法为: execute fun1
触发器是一种特殊类型的存储过程,当指定表中的数据发生变化时触发器自动生效,通常被用来约束数据完整性。
触发器不能设置参数、不能通过名称调用。触发器被作为事务来处理。
Create trigger t_student //对表Student添加数据时,都会有提示信息-‘准备插入数据’
on Student
after insert
as
print ‘准备插入数据’
游标
游标是取用一组数据并能够一次与一个单独的数据进行交互的方法。
通常select语句对整行产生作用,游标可以对某行的某列起作用。
//声明游标
declare my_cursor cursor for
select * from Student
where id=’1’
//打开游标
open my_cursor
go
事务、锁及其并发问题
事务是逻辑上相关的一些语句的集合。为了保障数据的一致性,这些语句要么全成功执行,要么执行失败进行回滚。
特性:原子性、一致性、隔离性、持久性。
begin transaction my_t //声明事务开始
update Student set name =’小明’
where id=1
commit transaction my_t ////提交事务
事务的并发问题有4种:
1.丢失更新。多个事务同时更新同一行如事务A、B同时修改小明的英语和语文成绩。
2.脏读。一个事物读取了另一个事务尚未提交的更新。
3.不可重复读。
4.幻象读。
涉及多个数据库的事务称为分布式事务
锁是一种机制,用来防止事务的并发问题。常见的有共享锁、更新锁、排它锁等。