数据库第三章SQL语言总结

SQL     结构化查询语言,是关系数据库的标准语言。

SQL 的特点:综合统一;高度非过程化;面向集合的操作方式;以同一种语法结构进行多种使用;语言简洁,易学易用;

基本表 :

           本身独立存在的表

           SQL中一个关系就对应一个基本表

           一个(或多个)基本表对应一个存储文件

          一个表可以带若干索引

存储文件 :

          逻辑结构组成了关系数据库的内模式

          物理结构对用户是隐蔽的

视图:

           从一个或几个基本表导出的表

           数据库中只存放视图的定义而不存放视图对应的数据

           视图是一个虚表

          用户可以在视图上再定义视图

 

学生-课程数据库

学生-课程模式 S-T :         

学生表:Student(Sno,Sname,Ssex,Sage,Sdept)

 课程表:Course(Cno,Cname,Cpno,Ccredit)

  学生选课表:SC(Sno,Cno,Grade)    

SQL的数据定义功能:

模式定义

表定义

视图和索引的定义

 

现代关系数据库管理系统提供了一个层次化的数据库对象命名机制

一个关系数据库管理系统的实例(Instance)中可以建立多个数据库

一个数据库中可以建立多个模式

一个模式下通常包括多个表、视图和索引等数据库对象

模式定义

定义模式实际上定义了一个命名空间。 在这个空间中可以定义该模式包含的数据库对象,例如基本表、视图、索引等。

模式删除

DROP SCHEMA <模式名> <CASCADE|RESTRICT>

CASCADE(级联)

删除模式的同时把该模式中所有的数据库对象全部删除

RESTRICT(限制)

如果该模式中定义了下属的数据库对象(如表、视图等),则拒绝该删除语句的执行。 仅当该模式中没有任何下属的对象时才能执行

定义基本表

<表名>:所要定义的基本表的名字

<列名>:组成该表的各个属性(列)

<列级完整性约束条件>:涉及相应属性列的完整性约束条件

<表级完整性约束条件>:涉及一个或多个属性列的完整性约束条件

数据类型

SQL中域的概念用数据类型来实现

定义表的属性时需要指明其数据类型及长度 选用哪种数据类型 取值范围 要做哪些运算

模式与表的关系

每一个基本表都属于某一个模式

一个模式包含多个基本表

定义基本表所属模式

方法一:在表名中明显地给出模式名 Create table"S-T".Student(......);  /*模式名为 S-T*/ Create table "S-T".Cource(......); Create table "S-T".SC(......);

方法二:在创建模式语句中同时创建表 方法三:设置所属的模式

修改基本表

ALTER TABLE <表名> [ ADD[COLUMN] <新列名> <数据类型> [ 完整性约束 ] ] [ ADD <表级完整性约束>] [ DROP [ COLUMN ] <列名> [CASCADE| RESTRICT] ] [ DROP CONSTRAINT<完整性约束名>[ RESTRICT | CASCADE ] ] [ALTER COLUMN <列名><数据类型> ] ;

修改基本表

ADD子句用于增加新列、新的列级完整性约束条件和新的表级完整性约束条件

DROP COLUMN子句用于删除表中的列 如果指定了CASCADE短语,则自动删除引用了该列的其他对象 如果指定了RESTRICT短语,则如果该列被其他对象引用,关系数据库管理系统将拒绝删除该列

DROP CONSTRAINT子句用于删除指定的完整性约束条件

ALTER COLUMN子句用于修改原有的列定义,包括修改列名和数据类型

删除基本表

DROP TABLE <表名>[RESTRICT| CASCADE];

RESTRICT:删除表是有限制的。 欲删除的基本表不能被其他表的约束所引用 如果存在依赖该表的对象,则此表不能被删除 CASCADE:删除该表没有限制。 在删除基本表的同时,相关的依赖对象一起删除

索引的建立与删除

建立索引的目的:加快查询速度

关系数据库管理系统中常见索引:

顺序文件上的索引

B+树索引

 散列(hash)索引

位图索引

特点:

B+树索引具有动态平衡的优点

HASH索引具有查找速度快的特点

索引的建立

CREATE [UNIQUE] [CLUSTER] INDEX <索引名> ON <表名>(<列名>[<次序>][,<列名>[<次序>] ]…);

<表名>:要建索引的基本表的名字

索引:可以建立在该表的一列或多列上,各列名之间用逗号分隔

<次序>:指定索引值的排列次序,

升序:ASC,降序:DESC。

缺省值:ASC

UNIQUE:此索引的每一个索引值只对应唯一的数据记录

CLUSTER:表示要建立的索引是聚簇索引

数据字典

数据字典是关系数据库管理系统内部的一组系统表,它记录了数据库中所有定义信息:

关系模式定义 视图定义 索引定义 完整性约束定义 各类用户对数据库的操作权限 统计信息等

关系数据库管理系统在执行SQL的数据定义语句时,实际上就是在更新数据字典表中的相应信息。

 

数据查询

 SELECT [ALL|DISTINCT] <目标列表达式>[,<目标列表达式>] …    

   FROM <表名或视图名>[,<表名或视图名> ]…|

(SELECT 语句)[AS]<别名> [ WHERE <条件表达式> ] [ GROUP BY <列名1> [ HAVING <条件表达式> ] ] [ ORDER BY <列名2> [ ASC|DESC ] ];

SELECT子句:指定要显示的属性列

FROM子句:指定查询对象(基本表或视图)

WHERE子句:指定查询条件

GROUP BY子句:对查询结果按指定列的值分组,该属性列值相等的元组为一个组。通常会在每组中作用聚集函数。

HAVING短语:只有满足指定条件的组才予以输出

ORDER BY子句:对查询结果表按指定列值的升序或降序排序

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值