基本概念
- 数据库系统(DBS)由数据库(DB),数据库管理系统(DBMS),应用系统和数据库管理员(DBA)构成;
- 数据模型的组成元素包括数据结构,数据操作和完整性约束;
- 关系模型的完整性约束包含实体完整性,参照完整性和用户自定义完整性;
- SQL语言具有数据定义,数据操纵,数据控制;SQL的五种基本操作包括:选择,投影,并,差和笛卡尔积(选择和投影);
数据库定义语言(DDL):CREATE, ALTER, DROP
数据库控制语言(DCL):GRANT, REVOKE
数据库操纵语言(DML):INSERT, REPLACE. UPDATE, DELETE
数据库查询语言(DQL):SELECT, WHERE, ORDER BY, GROUP BY, HAVING
事物处理语言:BEGIN, TRANSACTION, COMMIT - 数据库的模式:对数据库中全体数据的逻辑结构和特征的描述。
它的三级结构关系为:模式是内模式的逻辑表示,内模式是模式的物理实现,外模式是模式的部分抽取,其中主要存在两种映射:模式与子模式(外模式–>局部逻辑结构),模式与内模式(存储模式); - 网络协议的三个主要要素是语义,语法和定时;
- 元组表示行,用关键字来唯一标识,列表示属性;
- E-R图为实体-关系图,用于描述现实世界的事物及其相互关系,是数据库概念设计的主要工具;
- 主键:能够唯一的标识一个元组的属性或属性组称为关键的键或候选键,有多个候选键时,可以选择其中一个作为主键;
- 数据库的索引一般为或来实现;
- 数据库设计的六个基本步骤:需求分析–>概念设计–>逻辑结构设计–>物理结构设计–>数据库实施–>,数据库运行和维护。
- SQL执行的顺序:from–>where–>group by–>having–>select–>order by -->limit;
- 视图是虚拟的表,不包含数据,是用来查看存储在别处数据的一种设施,在添加或更改这些表中的数据时,视图将返回改变过的数据,命名唯一,,需要足够的访问权限,禁止使用order by,。
范式
符合某一级别的关系模式的集合:
1.:无重复的列,每一列都是不可分割的基本数据流,同一列中不能有多个值;
2. :属性完全依赖于主键,每个实例或行必须可以被唯一的区分;
3. :属性不依赖于其它非主属性(消除传递依赖);
4. :关系模式的每一个决定因素都包含码;
联结
1.自联结:用来替代从相同表中检索数据的使用子查询语句
SELECT c1.cut_id, c1.cut_name, c2.cut_contact
FROM Customers AS c1, Customers AS c2
WHERE c1.cut_name = c2.cut_name AND c2.cut_contact = ‘JIM’;
2.自然联结:相同的列多次出现时,使每一列只返回一次
SELECT c.*, o.order_num, o.date
FROM customers as c , orders as o, orderitems as oi
where c.cust_id = o.cust_id AND oi.order_num = o.order_num
3.外联结:联结包含了在相关表中没有关联行的行
SELECT customers.cut_id, orders.ord_num
FROM customers RIGHT OUTER JOIN orders ON orders.cut_id = customers.cut_id;
INNER JOIN ON
LEFT JOIN ON
数据库事务
指用户定义的一种数据库操作序列,包含四种性质:
:事务作为一个整体被执行,包含在其中的对数据库的操作要么全部执行,要么全部不执行;
:事务应确保数据库的状态从一个一致状态转变为另一个一致状态,也就是需要满足完整性约束;
:多个事务并发执行时,一个事务的执行不应该影响其它事务的执行;
:已被提交的事务对数据库的修改应该永久保存在数据库中。
数据库索引的优点
1.可以保证数据库表中每行数据的唯一性
2.可以大大加快数据的检索速度
3.可以加快表与表之间的连接
4.在使用分组和排序子句进行数据检查时,可以显著减少查询中分组和排序的时间
5.通过使用索引,可以在查询的过程中,使用优化隐藏器,提高系统的性能
常用的命令语句
权限修改命令
(1)将student和course表的全部权限授予所有用户
TABLE student, course PUBLIC
(2)将对student表的查询权和姓名修改权授予用户U4
GRANT SELECT, UPDATE(Sname) ON TABLE student TO U4
(3)将对SC表的插入权限授予用户U5,并允许它传播该权限
GRANT INSERT ON TABLE SC TO U5
(4)将用户U5对SC表的INSERT权限收回,同时收回被他传播出去的授权
INSERT ON TABLE SC U5 CASCADE
(5)创建一个角色R1,并使其对student表具有数据查询和更新权限
CREATE ROLE R1;
GRANT SELECT, UPDATE ON TABLE student TO R1;
(6)对修改student表结构的操作进行审计
AUDIT ALTER ON student;