第一章
数据模型三要素:数据结构,数据操纵,完整性约束
主要的数据模型:层次模型,网状模型,关系模型
完整性约束:实体完整性,参照完整性,用户定义完整性
数据库管理系统将具有一定结构的数据组成一个集合,它主要具有以下几个特点:
1. 数据的结构化 数据库中的数据并不是杂乱无章、毫不相干的,它们具有一定的组织结构,属于同一集合的数据具有相似的特征。
2. 数据的共享性 在一个单位的各个部门之间,存在着大量的重复信息。使用数据库的目的就是要统一管理这些信息,减少冗余度,使各个
部门共同享有相同的数据。
3. 数据的独立性 数据的独立性是指数据记录和数据管理软件之间的独立。数据及其结构应具有独立性,而不应该去改变应用程序。
4. 数据的完整性 数据的完整性是指保证数据库中数据的正确性。可能造成数据不正确的原因很多,数据库管理系统通过对数据性质进行检
查而管理它们。
5. 数据的灵活性 数据库管理系统不是把数据简单堆积,它在记录数据信息的基础上具有很多的管理功能,如输入、输出、查询、编辑修改
等。
6. 数据的安全性 根据用户的职责,不同级别的人对数据库具有不同的权限,数据库管理系统应该确保数据的安全性。
SQL命令基本分类:
1.数据定义语言DDL
2.数据操作语言DML
3.数据查询语言DQL
4.数据控制语言DCL
5.数据管理命令
6.事务控制命令
1.
CREATE TABLE/INDEX/VIEW
ALTER TABLE/INDEX
DROP TABLE/INDEX/VIEW
2.
INSERT
UPDATA
DELETE
3.
SELECT
4.
ALTER PASSWORD
GRANT(授予)
REVOKE
CREATE SYNONYM(同义字)
5.
START/STOP AUDIT(查账)
6.
COMMIT 保存数据库事务
ROLLBACK 回退
SAVEPOINT 设置标记点用于回退
SET TRANSACTION 设置事务名称
字段:
例如“ID”“姓”“名”
记录:
一行数据
列:
特定字段的全部信息
主键:
例如“ID”
第二章 数据定义
DECIMAL(p,s) //小数
例如DECIMAL(4,2),则形如99.99
1.DATE
2.TIME
3.DATETIME
4.TIMESTAMP
CREATE TYPE PERSON AS OBJECT
(NAME VARCHAR(30),
SSN VARCHAR(9));
CREATE TABLE EMP_PAY
(EMPLOYEE PERSON,
SLKARY DECIMAL(10,2),
HIRE_DATA DATE);
默认约束和检查约束还有数据类型都可以实现域完整性
下面是详细资料~
完整性包括
1. 实体完整性
a) 数据行不能存在重复
2. 域完整性
a) 实现了对输入到特定列的数值的限制
3. 引用完整性
a) 要求子表中的相关项必须在主表中存在
b) 如果建立了主表和子表的关系,则:
i. 子表中的相关项目的数据,在主表中必须存在;
ii. 主表中相关项的数据更改了,则子表对应的数据项也应当随之更改;
iii. 在删除子表之前,不能够删除主表;
4. 自定义完整性
实际上,SQL Server创建表的过程是规定数据列的属性的过程,同时也是实施数据完整性(包括实体完整性、引用完整性和域完整性等)保证的过程。创建表包括选择字段名称、数据类型、定义是否为空、设置默认值、主键和外键关系、检查约束等。表中没有合适的列作为主键,可以创建标识列。
SQL Server中存在五种约束:
• 约束的目的:确保表中数据的完整型
• 常用的约束类型:
– 主键约束(Primary Key Constraint):要求主键列数据唯一,并且不允许为空
– 唯一约束(Unique Constraint):要求该列唯一,允许为空,但只能出现一个空值。
– 检查约束(Check Constraint):某列取值范围限制、格式限制等,如有关年龄的约束
– 默认约束(Default Constraint):某列的默认值,如我们的男性学员较多,性别默认为“男”
– 外键约束(Foreign Key Constraint):用于两表间建立关系,需要指定引用主表的那列
CREATE DOMAIN MONEY_D AS NUMBER(8.2);
ALTER DOMAIN MONEY_D
ADD CONSTRANT MONEY_CON1
CHECK (VALUE > 5);
一个numeric类型的标度(scale)是小数部分的位数,精度(precision)是全部数据位的数目
第三章
数据库对象:
表、视图、簇、序列、索引、异名
规划:
与某个用户名相关的数据库对象集合,例如该用户创建的数据库对象
USER1.EMPLOYEE_TBL
ID SERIAL //则ID自动增加
INSERT INTO TEST_INCREMENT(TESR_NAME)
VALUES('FRED'),('JOE'),('MIKE'),('TED');
CREATE TABLE AS SELECT //MySQL
SELECT INTO //MSQLS
create table products2 as select * from products1;
select * into products2 from products1;
drop table products1;
主键约束:
CREATE TABLE EMPLOYEE
(ID CHAR(9) NOT NULL PRIMARY KEY,
NAME VARCHAR(40) NOT NULL UNIQUE, //唯一性约束
...
PAGER INTERGER(10) NULL);
//PRIMARY KEY (ID) );
//ALTER TABLE EMPLOYEE ADD CONSTRAINT PK PRIMARY KEY (ID, NAME);
外键约束:
CREATE TABLE PAYMENT
(PID CHAR(9) NOT NULL,
...
CONSTRANT FK FOREIGN KEY (PID) REFERENCES EMPLOYEE (ID) );
//父表子表关系,引用完整性
//ALTER TABLE PAYMENT ADD CONSTRANT FK FOREIGN KEY (PID) REFERENCES EMPLOYEE (ID);
检查约束:
...
CONSTRAINT CHK CHECK (ZIP = '10000') );
ALTER TABLE EMPLOYEE DROP CONSTRAINT PK;
ALTER TABLE EMPLOYEE MODIFY MIDDLE_NAME VARCHAR(20), NOT NULL
ALTER TABLE EMPLOYEE ADD COLUMN EMPID INT AUTO_INCREMENT;
第四章
规格化:
把原始刷数据分解为表,去除冗余数据的过程
第一规格形式:
把原始数据分解到表中
第二规格形式:
把对主键仅有部分依赖的数据提取到另一个表里
第三规格形式:
删除表里不依赖主键的数据(例如职位描述)
第五章 数据操作
INSERT INTO PRODUCTS VALUES ('1123','LEATHER',24,99);
第六章 管理数据库事务