数据库相关知识点

主键: 能够唯一地标识一个元组的属性或属性组称为关系的键或候选键。 若一个关系有多个候选键则可选其一作为主键(Primary key)。

   2. 外键:如果一个关系的一个或一组属性引用(参照)了另一个关系的主键,则称这个或这组属性为外码或外键(Foreign key)。

   3. 关系数据库: 依照关系模型建立的数据库称为关系数据库。 它是在某个应用领域的所有关系的集合。

   4. 关系模式: 简单地说,关系模式就是对关系的型的定义, 包括关系的属性构成、各属性的数据类型、 属性间的依赖、 元组语义及完整性约束等。 关系是关系模式在某一时刻的状态或内容, 关系模型是型, 关系是值, 关系模型是静态的、 稳定的, 而关系是动态的、随时间不断变化的,因为关系操作在不断地更新着数据库中的数据。

   5. . 实体完整性:用于标识实体的唯一性。它要求基本关系必须要有一个能够标识元组唯一性的主键,主键不能为空,也不可取重复值。

   6. 参照完整性: 用于维护实体之间的引用关系。 它要求一个关系的外键要么为空, 要么取与被参照关系对应的主键值,即外键值必须是主键中已存在的值。

   7. 用户定义的完整性:就是针对某一具体应用的数据必须满足的语义约束。包括非空、 唯一和布尔条件约束三种情况。

Data:数据,是数据库中存储的基本对象,是描述事物的符号记录。
Database:数据库,是长期储存在计算机内、有组织的、可共享的大量数据的集合。
. DBMS:数据库管理系统,是位于用户与操作系统之间的一层数据管理软件,用于科学地组织、存储和管理数据、高效地获取和维护数据。
. DBS:数据库系统,指在计算机系统中引入数据库后的系统,一般由数据库、数据库管理系统、应用系统、数据库管理员(DBA)构成。
. 数据模型:是用来抽象、表示和处理现实世界中的数据和信息的工具,是对现实世界的模拟,是数据库系统的核心和基础;其组成元素有数据结构、数据操作和完整性约束。
SQL:结构化查询语言的简称, 是关系数据库的标准语言。SQL 是一种通用的、 功能极强的关系数据库语言, 是对关系数据存取的标准接口, 也是不同数据库系统之间互操作的基础。集数据查询、数据操作、数据定义、和数据控制功能于一体。

    数据定义:数据定义功能包括模式定义、表定义、视图和索引的定义。

    嵌套查询:指将一个查询块嵌套在另一个查询块的 WHERE 子句或 HAVING 短语的条件中的查询。

  二、重要知识点
   1. SQL 数据定义语句的操作对象有:模式、表、视图和索引。
   2. SQL 数据定义语句的命令动词是:CREATE、DROP 和 ALTER。
   3. RDBMS 中索引一般采用 B+树或 HASH 来实现。
   4. 索引可以分为唯一索引、非唯一索引和聚簇索引三种类型。
   
   算术表达式列表:一个或多个逗号分隔的算术表达式,表达式由常量(包括数字和字符串)、列名、函数和算术运算符构成。每个表达式后还可跟别名。也可用 *代表查询表中的所有列。

  <表名或视图名列表>: 一个或多个逗号分隔的表或视图名。 表或视图名后可跟别名。

  条件表达式 1:包含关系或逻辑运算符的表达式,代表查询条件。

  条件表达式 2:包含关系或逻辑运算符的表达式,代表分组条件。

  <属性列表 1>:一个或逗号分隔的多个列名。

  <属性列表 2>: 一个或逗号分隔的多个列名, 每个列名后可跟 ASC 或 DESC, 表示升/降序,缺省为升序。
  SQL语句总结

SQL语句中常用关键词及其解释如下:

1)SELECT
将资料从数据库中的表格内选出,两个关键字:从 (FROM) 数据库中的表格内选出 (SELECT)。语法为
SELECT “栏位名” FROM “表格名”。
2)DISTINCT
在上述 SELECT 关键词后加上一个 DISTINCT 就可以去除选择出来的栏位中的重复,从而完成求得这个表格/栏位内有哪些不同的值的功能。语法为
SELECT DISTINCT “栏位名” FROM “表格名”。
3)WHERE
这个关键词可以帮助我们选择性地抓资料,而不是全取出来。语法为
SELECT “栏位名” FROM “表格名” WHERE “条件”
4)AND OR
上例中的 WHERE 指令可以被用来由表格中有条件地选取资料。这个条件可能是简单的 (像上一页的例子),也可能是复杂的。复杂条件是由二或多个简单条件透过 AND 或是 OR 的连接而成。语法为:
SELECT “栏位名” FROM “表格名” WHERE “简单条件” {[AND|OR] “简单条件”}+
5)IN
在 SQL 中,在两个情况下会用到 IN 这个指令;这一页将介绍其中之一:与 WHERE 有关的那一个情况。在这个用法下,我们事先已知道至少一个我们需要的值,而我们将这些知道的值都放入 IN 这个子句。语法为:
SELECT “栏位名” FROM “表格名” WHERE “栏位名” IN (‘值一’, ‘值二’, …)
6)BETWEEN
IN 这个指令可以让我们依照一或数个不连续 (discrete)的值的限制之内抓出资料库中的值,而 BETWEEN 则是让我们可以运用一个范围 (range) 内抓出资料库中的值,语法为:
SELECT “栏位名” FROM “表格名” WHERE “栏位名” BETWEEN ‘值一’ AND ‘值二’
7)LIKE
LIKE 是另一个在 WHERE 子句中会用到的指令。基本上, LIKE 能让我们依据一个模式(pattern) 来找出我们要的资料。语法为:
SELECT “栏位名” FROM “表格名” WHERE “栏位名” LIKE {模式}
8)ORDER BY
我们经常需要能够将抓出的资料做一个有系统的显示。这可能是由小往大 (ascending) 或是由大往小(descending)。在这种情况下,我们就可以运用 ORDER BY 这个指令来达到我们的目的。语法为:
SELECT “栏位名” FROM "表格名 [WHERE “条件”] ORDER BY “栏位名” [ASC, DESC]
9)函数
函数允许我们能够对这些数字的型态存在的行或者列做运算,包括 AVG (平均)、COUNT (计数)、MAX (最大值)、MIN (最小值)、SUM (总合)。语法为:
SELECT “函数名”(“栏位名”) FROM “表格名”
10)COUNT
这个关键词能够帮我我们统计有多少笔资料被选出来,语法为:
SELECT COUNT(“栏位名”) FROM “表格名”
11)GROUP BY
GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。语法为:
SELECT “栏位1”, SUM(“栏位2”) FROM “表格名” GROUP BY “栏位1”
12)HAVING
该关键词可以帮助我们对函数产生的值来设定条件。语法为:
SELECT “栏位1”, SUM(“栏位2”) FROM “表格名” GROUP BY “栏位1” HAVING (函数条件)
13)ALIAS
我们可以通过ALIAS为列名称和表名称指定别名,语法为:
SELECT “表格别名”.“栏位1” “栏位别名” FROM “表格名” “表格别名”
事务

事务是数据库中一个单独的执行单元,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。 事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。通过将一组相关操作组合为一个要么全部成功要么全部失败的单元,可以简化错误恢复并使应用程序更加可靠。一个逻辑工作单元要成为事务,必须满足所谓的ACID(原子性atomicity、一致性consistency、隔离性isolation和持久性durability)属性。事务是数据库运行中的一个逻辑工作单位,由DBMS中的事务管理子系统负责事务的处理。

严格来说,数据库事务属性ACID都是有数据库管理系统来进行保证的,在整个应用程序执行的过程中应用无需去考虑数据库的ACID实现。

事务——指一组SQL语句

回退——指撤销指定的SQL语句和过程

提交——指将未存储的SQL语句结果写入数据库表

保留点——指事务处理中设置的临时占位符,可以对它发布回退(与回退整个事务处理不同)

使用ROLLBACK(SQL)命令来回退(撤销)SQL语句

使用COMMIT进行明确的提交

SAVEPOINT或SAVE TRANSACTION设置保留点(不同DBMS不同)
存储过程

SQL语句要先编译,然后再被执行。在大型数据库系统中,为了提高效率,将为了完成特定功能的SQL语句集进行编译优化后,存储在数据库服务器中,用户通过指定存储过程的名字来调用执行。

使用存储过程可以增强SQL语句的功能和灵活性,并且可以保证数据的安全性和完整性,同时存储过程可以使没有权限的用户在控制之下间接地存取数据库,也保证了数据的安全。

但存储过程不等同于函数,两者虽然本质上没有区别,但还是有以下几方面的区别:
(1)存储过程一般是作为独立的部分来执行的,而函数可以作为查询语句的一个部分来调用

(2)一般存储过程实现的功能较为复杂,函数实现的功能针对性较强

(3)存储过程可以返回多个参数,而函数只能返回一个参数

(4)函数可以嵌入在SQL中使用,可以在select中调用,但存储过程不能

(5)函数不能直接操作实体表,只能操作内建表

(6)存储过程在创建时即在服务器上进行了编译,执行速度更快

范化是在识别数据库中的数据元素、关系、以及定义所需的表和各表中的项目这些初始工作之后的一个细化过程。
1NF,第一范式。第一范式是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性。第一范式要求属性值不可再分裂成更小部分,即属性项不能是属性组合或由组属性组成。
2NF,第二范式。满足第一范式,并且要求数据库表的每个实例或行必须可以被唯一地区分。例如:在选课关系表中(学号,课程号,成绩,学分),关键字为组合关键字(学号,课程号),但是非主属性学分对关键字只是部分依赖,而不是完全依赖。 解决办法是将其分为两个关系模式:学生表(学号,课程号,分数)和课程表(课程号,学分)。新关系通过学生表中外关键字课程号联系,在需要时进行连接。
3NF,第三范式。如果关系模式R是第二范式,且每个非主属性都不传递依赖于R的候选键,则称R是第三范式的模式。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值