数据库:存放与管理数据的仓库,是逻辑上相关的数据的集合。优点有:减少数据冗余度、具有较高的独立性、便于数据共享。
数据库系统:由数据库及其管理软件组成的系统。
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
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.幻象读。
涉及多个数据库的事务称为分布式事务
锁是一种机制,用来防止事务的并发问题。常见的有共享锁、更新锁、排它锁等。