数据库课件-第3章 关系数据库标准语言SQL_2_第1页
数据库课件-第3章 关系数据库标准语言SQL_2_第2页
数据库课件-第3章 关系数据库标准语言SQL_2_第3页
数据库课件-第3章 关系数据库标准语言SQL_2_第4页
数据库课件-第3章 关系数据库标准语言SQL_2_第5页
已阅读5页,还剩84页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、2022/4/30数据库技术与应用数据库技术与应用Database Technology and Application2013年4月第三章第三章 关系数据库标准语言关系数据库标准语言SQL2022/4/303.4 3.4 数数 据据 更更 新新 3.4.1 插入数据插入数据3.4.2 修改数据修改数据3.4.3 删除数据删除数据 2022/4/303.4.1 3.4.1 插入数据插入数据v两种插入数据方式两种插入数据方式1. 插入元组插入元组2. 插入子查询结果插入子查询结果可以一次插入多个元组可以一次插入多个元组 2022/4/30一、插入元组一、插入元组v 语句格式语句格式INSERTI

2、NTO (,)VALUES ( , )v 功能功能n将新元组插入指定表中将新元组插入指定表中2022/4/30插入元组(续)插入元组(续)v INTO子句子句M指定要插入数据的表名及属性列指定要插入数据的表名及属性列M属性列的顺序可与表定义中的顺序不一致属性列的顺序可与表定义中的顺序不一致M没有指定属性列没有指定属性列:表示要插入的是一条完整的元组,且:表示要插入的是一条完整的元组,且属性列属性与表定义中的顺序一致属性列属性与表定义中的顺序一致M指定部分属性列:插入的元组在其余属性列上取空值指定部分属性列:插入的元组在其余属性列上取空值v VALUES子句子句M提供的值必须与提供的值必须与IN

3、TO子句匹配子句匹配值的个数值的个数值的类型值的类型2022/4/30插入元组(续)插入元组(续)例例1 将一个新学生元组(学号:将一个新学生元组(学号:0903128;姓名:;姓名:陈冬;性别:男;所在系:陈冬;性别:男;所在系:IS;年龄:;年龄:18岁)插入岁)插入到到Student表中。表中。 INSERT INTO Student (Sno, Sname, Ssex, Sdept, Sage) VALUES (0903128,陈冬陈冬,男男,IS,18);2022/4/30 例例2 2将学生张成民的信息插入到将学生张成民的信息插入到Student表中表中 INSERT INTO St

4、udent VALUES (0903126, 张成民张成民, 男男,18,CS); 插入元组(续)插入元组(续)例例3 插入一条选课记录插入一条选课记录( 0903128,1 )。 INSERT INTO SC(Sno,Cno) VALUES ( 0903128 , 1 ); RDBMS将在新插入记录的将在新插入记录的Grade列上自动地赋空值。列上自动地赋空值。 或者:或者: INSERT INTO SC VALUES ( 0903128 , 1 ,NULL);2022/4/30二、插入子查询结果二、插入子查询结果v语句格式语句格式 INSERT INTO ( , ) 子查询子查询;v功能功

5、能 将子查询结果插入指定表中将子查询结果插入指定表中2022/4/30插入子查询结果(续)插入子查询结果(续)v INTO子句子句(与插入元组类似与插入元组类似)v 子查询子查询nSELECT子句目标列必须与子句目标列必须与INTO子句匹配子句匹配值的个数值的个数值的类型值的类型2022/4/30插入子查询结果(续)插入子查询结果(续)例例4 对每一个系,求学生的平均年龄,并把结果存对每一个系,求学生的平均年龄,并把结果存入数据库。入数据库。第一步:建表第一步:建表 CREATE TABLE Dept_age (Sdept CHAR(15) /* 系名系名*/ Avg_age SMALLINT

6、); /*学生平均年龄学生平均年龄*/ 2022/4/30插入子查询结果(续)插入子查询结果(续)第二步:插入数据第二步:插入数据 INSERT INTO Dept_age(Sdept,Avg_age) SELECT Sdept,AVG(Sage) FROM Student GROUP BY Sdept;2022/4/30插入子查询结果(续)插入子查询结果(续)RDBMS在执行插入语句时会检查所插元组是否破坏在执行插入语句时会检查所插元组是否破坏表上已定义的表上已定义的完整性规则完整性规则:M实体完整性实体完整性M参照完整性参照完整性M用户定义的完整性用户定义的完整性NOT NULL约束约束U

7、NIQUE约束约束值域约束值域约束2022/4/303.4 3.4 数数 据据 更更 新新 3.4.1 插入数据插入数据3.4.2 修改数据修改数据3.4.3 删除数据删除数据 2022/4/303.4.2 3.4.2 修改数据修改数据v语句格式语句格式 UPDATE SET =,= WHERE ;v功能功能n修改指定表中满足修改指定表中满足WHERE子句条件的元组子句条件的元组2022/4/30修改数据(续)修改数据(续)nSET子句指定子句指定修改方式(修改方式(3种)种)修改某一个元组的值修改某一个元组的值修改多个元组的值修改多个元组的值带子查询的修改语句带子查询的修改语句要修改的列要修

8、改的列修改后取值修改后取值nWHERE子句指定子句指定要修改的元组要修改的元组缺省表示要修改表中的所有元组缺省表示要修改表中的所有元组2022/4/301. 修改某一个元组的值修改某一个元组的值例例5 将学生将学生0903121的年龄改为的年龄改为22岁岁 UPDATE Student SET Sage=22 WHERE Sno= 0903121 ; 2022/4/302. 修改多个元组的值修改多个元组的值例例6 将所有学生的年龄增加将所有学生的年龄增加1岁岁 UPDATE Student SET Sage= Sage+1;2022/4/303. 带子查询的修改语句带子查询的修改语句例例7 将

9、计算机科学系全体学生的成绩置零。将计算机科学系全体学生的成绩置零。 UPDATE SC SET Grade=0 WHERE CS= (SELECT Sdept FROM Student WHERE Student.Sno = SC.Sno);或:或:UPDATE SC SET Grade=0 WHERE SC.Sno IN (SELECT Sno FROM Student WHERE Sdept =CS );2022/4/30修改数据(续)修改数据(续)RDBMS在执行修改语句时会检查修改操作是否破在执行修改语句时会检查修改操作是否破坏表上已定义的坏表上已定义的完整性规则完整性规则n实体完整性

10、实体完整性n主码不允许修改主码不允许修改n用户定义的完整性用户定义的完整性 NOT NULL约束约束 UNIQUE约束约束 值域约束值域约束2022/4/303.4 3.4 数数 据据 更更 新新 3.4.1 插入数据插入数据3.4.2 修改数据修改数据3.4.3 删除数据删除数据 2022/4/303.4.3 3.4.3 删除数据删除数据v语句格式语句格式 DELETE FROM WHERE ;v功能功能n删除指定表中满足删除指定表中满足WHERE子句条件的元组子句条件的元组vWHERE子句子句n指定要删除的元组指定要删除的元组n缺省表示要删除表中的全部元组,表的定义仍在字典中缺省表示要删除

11、表中的全部元组,表的定义仍在字典中2022/4/30删除数据(续)删除数据(续)v三种删除方式三种删除方式:1. 删除某一个元组的值删除某一个元组的值2. 删除多个元组的值删除多个元组的值3. 带子查询的删除语句带子查询的删除语句2022/4/301. 删除某一个元组的值删除某一个元组的值例例8 删除学号为删除学号为0903128的学生记录。的学生记录。 DELETE FROM Student WHERE Sno=0903128 ;2022/4/302. 删除多个元组的值删除多个元组的值例例9 删除所有的学生选课记录。删除所有的学生选课记录。 DELETE FROM SC;2022/4/303

12、. 带子查询的删除语句带子查询的删除语句例例10 删除计算机科学系所有学生的选课记录。删除计算机科学系所有学生的选课记录。 DELETE FROM SC WHERE CS= (SELECT Sdept FROM Student WHERE Student.Sno=SC.Sno);2022/4/30删除数据删除数据(续续)DBMS在执行删除语句时会检查所删除元组是否破在执行删除语句时会检查所删除元组是否破坏表上已定义的完整性规则,参照完整性,若破坏表上已定义的完整性规则,参照完整性,若破坏,则坏,则不允许删除不允许删除级联删除级联删除2022/4/30第三章第三章 关系数据库标准语言关系数据库标

13、准语言SQL2022/4/303.5 3.5 视视 图图视图的特点视图的特点v虚表虚表,是从一个或几个基本表(或视图)导出的,是从一个或几个基本表(或视图)导出的表表v数据库中只存放数据库中只存放视图的定义视图的定义,不存放视图对应的,不存放视图对应的数据数据v基表中的数据发生变化,从视图中查询出的数据基表中的数据发生变化,从视图中查询出的数据也随之改变也随之改变2022/4/303.5 3.5 视视 图图基于视图的操作基于视图的操作v 查询查询v 删除删除v 受限更新受限更新v 定义基于该视图的新视图定义基于该视图的新视图2022/4/303.5 3.5 视视 图图3.5.1 定义视图定义视

14、图3.5.2 查询视图查询视图3.5.3 更新视图更新视图3.5.4 视图的作用视图的作用2022/4/303.5.1 3.5.1 定义视图定义视图v建立视图建立视图v删除视图删除视图2022/4/30一、建立视图一、建立视图v语句格式语句格式 CREATE VIEW ( ,) AS WITH CHECK OPTION;v组成视图的属性列名:全部省略或全部指定组成视图的属性列名:全部省略或全部指定v子查询不允许含有子查询不允许含有ORDER BY子句和子句和DISTINCT短语短语2022/4/30组成视图的属性列名组成视图的属性列名属性列名可全部省略属性列名可全部省略或或全部指定全部指定M全

15、部省略全部省略: 由子查询中由子查询中SELECT目标列中的诸字段组成目标列中的诸字段组成M全部指定所有列名的情况全部指定所有列名的情况:(1) 某个目标列是集函数或列表达式某个目标列是集函数或列表达式(2) 多表连接时选出了几个同名列作为视图的字段多表连接时选出了几个同名列作为视图的字段(3) 需要在视图中为某个列启用新的更合适的名字需要在视图中为某个列启用新的更合适的名字2022/4/30 建立视图(续)建立视图(续)vRDBMS执行执行CREATE VIEW语句时语句时只是把只是把视图视图定义定义存入数据字典存入数据字典,并不执行其中的,并不执行其中的SELECT语语句。句。v在对视图查

16、询时,按视图的定义从基本表中将数在对视图查询时,按视图的定义从基本表中将数据查出。据查出。2022/4/30建立视图(续)建立视图(续) 例例1 建立信息系学生的视图。建立信息系学生的视图。 CREATE VIEW IS_Student AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept= IS;2022/4/30建立视图(续)建立视图(续)例例2建立信息系学生的视图,并要求进行修改和插建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生入操作时仍需保证该视图只有信息系的学生 。 CREATE VIEW IS_Stude

17、nt AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept= IS WITH CHECK OPTION;2022/4/30建立视图(续)建立视图(续)对对IS_Student视图的更新操作:视图的更新操作:v修改操作:自动加上修改操作:自动加上Sdept= IS的条件的条件v删除操作:自动加上删除操作:自动加上Sdept= IS的条件的条件v插入操作:自动检查插入操作:自动检查Sdept属性值是否为属性值是否为IS M如果不是,则拒绝该插入操作如果不是,则拒绝该插入操作M如果没有提供如果没有提供Sdept属性值,则自动定义属性值,则自动定义Sdep

18、t为为IS2022/4/30建立视图(续)建立视图(续)v基于多个基表的视图基于多个基表的视图例例3 建立信息系选修了建立信息系选修了1号课程的学生视图。号课程的学生视图。 CREATE VIEW IS_S1(Sno,Sname,Grade) AS SELECT Student.Sno,Sname,Grade FROM Student,SC WHERE Sdept= IS AND Student.Sno=SC.Sno AND SC.Cno= 1;2022/4/30建立视图(续)建立视图(续)v基于视图的视图基于视图的视图例例4 建立信息系选修了建立信息系选修了1号课程且成绩在号课程且成绩在90

19、分以分以上的学生的视图。上的学生的视图。 CREATE VIEW IS_S2 AS SELECT Sno,Sname,Grade FROM IS_S1 WHERE Grade=90;2022/4/30建立视图(续)建立视图(续)v带表达式的视图带表达式的视图例例5 定义一个反映学生出生年份的视图。定义一个反映学生出生年份的视图。 CREATE VIEW BT_S(Sno,Sname,Sbirth) AS SELECT Sno,Sname,2012-Sage FROM Student;2022/4/30建立视图(续)建立视图(续)v分组视图分组视图例例6 将学生的学号及他的平均成绩定义为一个视图

20、将学生的学号及他的平均成绩定义为一个视图(假设(假设SC表中表中“成绩成绩”列列Grade为数字型)。为数字型)。 CREAT VIEW S_G(Sno,Gavg) AS SELECT Sno,AVG(Grade) FROM SC GROUP BY Sno;2022/4/30 建立视图(续)建立视图(续)v不指定属性列不指定属性列例例7将将Student表中所有女生记录定义为一个视图表中所有女生记录定义为一个视图CREATE VIEW F_Student(F_Sno, name, sex, age, dept)ASSELECT *FROM StudentWHERE Ssex=女女;缺点:缺点:

21、以以 SELECT * 方式创建的视图方式创建的视图可扩充性差可扩充性差,应尽可能避免。,应尽可能避免。原因:原因:修改基表修改基表Student的结构后,的结构后,Student表与表与F_Student视图视图的映象关系被破坏,导致该视图不能正确工作。的映象关系被破坏,导致该视图不能正确工作。2022/4/30 建立视图(续)建立视图(续)CREATE VIEW F_Student2 (stdnum, name, sex, age, dept)ASSELECT Sno,Sname,Ssex,Sage,SdeptFROM StudentWHERE Ssex=女女;为基表为基表Student增

22、加属性列不会破坏增加属性列不会破坏Student表与表与F_Student2视图的映象关系。视图的映象关系。2022/4/30二、删除视图二、删除视图v语句的格式:语句的格式:DROP VIEW ;M该语句从该语句从数据字典数据字典中删除指定的中删除指定的视图定义视图定义M如果该视图上还导出了其他视图,使用如果该视图上还导出了其他视图,使用CASCADE级联删除语句,把该视图和由它级联删除语句,把该视图和由它导出的所有视图一起删除导出的所有视图一起删除 M删除删除基表基表时,由该基表导出的时,由该基表导出的所有视图定义所有视图定义都必须显式地使用都必须显式地使用DROP VIEW语句删除语句删

23、除 2022/4/30删除视图删除视图(续)续)例例8 删除视图删除视图BT_S: DROP VIEW BT_S; 删除视图删除视图IS_S1:DROP VIEW IS_S1;级联删除:级联删除: DROP VIEW IS_S1 CASCADE; 2022/4/303.5 3.5 视视 图图3.5.1 定义视图定义视图3.5.2 查询视图查询视图3.5.3 更新视图更新视图3.5.4 视图的作用视图的作用2022/4/303.5.2 3.5.2 查询视图查询视图v 用户角度:查询视图与查询基本表相同用户角度:查询视图与查询基本表相同v RDBMS实现视图查询的方法实现视图查询的方法M通过视图消

24、解法(通过视图消解法(View Resolution)完成)完成进行有效性检查,检查所查询的视图是否存在进行有效性检查,检查所查询的视图是否存在若视图存在,将其定义中的子查询和用户查询结若视图存在,将其定义中的子查询和用户查询结合起来,转换成合起来,转换成等价的对基本表的查询等价的对基本表的查询执行执行修正修正后的查询后的查询2022/4/30查询视图(续)查询视图(续)例例9 在信息系学生的视图中找出年龄小于在信息系学生的视图中找出年龄小于20岁的学生。岁的学生。 SELECT Sno,Sage FROM IS_Student WHERE Sage20;IS_Student视图的定义视图的定

25、义 CREATE VIEW IS_Student AS SELECT Sno,Sname,Sage FROM Student WHERE Sdept= IS;2022/4/30查询视图(续)查询视图(续)视图消解转换后的查询语句为:视图消解转换后的查询语句为: SELECT Sno,Sage FROM Student WHERE Sdept= IS AND Sage=90; S_G视图的子查询定义:视图的子查询定义: CREATE VIEW S_G (Sno,Gavg) AS SELECT Sno,AVG(Grade)FROM SCGROUP BY Sno;2022/4/30查询转换查询转换将

26、查询语句与将查询语句与S_G视图的定义相结合:视图的定义相结合:SELECT Sno,AVG(Grade)FROM SCWHERE AVG(Grade)=90GROUP BY Sno;因因WHERE子句不可用聚集函数,这种转换不合理,出子句不可用聚集函数,这种转换不合理,出现语法错误现语法错误正确:正确:SELECT Sno,AVG(Grade)FROM SCGROUP BY SnoHAVING AVG(Grade)=90;2022/4/303.5 3.5 视视 图图3.5.1 定义视图定义视图3.5.2 查询视图查询视图3.5.3 更新视图更新视图3.5.4 视图的作用视图的作用2022/4

27、/303.5.3 3.5.3 更新视图更新视图v用户角度:更新视图与更新基本表相同用户角度:更新视图与更新基本表相同vDBMS实现视图更新的方法实现视图更新的方法视图消解法,转换为对视图消解法,转换为对基本表基本表的操作的操作v指定指定WITH CHECK OPTION子句后子句后 DBMS在更新视图时会进行检查,防止用户通过在更新视图时会进行检查,防止用户通过视图对视图对不属于视图范围内不属于视图范围内的基本表数据进行更新的基本表数据进行更新2022/4/30更新视图(续)更新视图(续)例例12 将信息系学生将信息系学生视图视图IS_Student中学号中学号0903122的学生姓名改为的学

28、生姓名改为“刘辰刘辰”。UPDATE IS_StudentSET Sname= 刘辰刘辰WHERE Sno= 0903122 ;转换后的语句:转换后的语句:UPDATE StudentSET Sname= 刘辰刘辰WHERE Sno= 0903122 AND Sdept= IS;2022/4/30更新视图(续)更新视图(续)例例13 向信息系学生向信息系学生视图视图IS_Student中插入一个中插入一个新的学生记录:新的学生记录:95029,赵新,赵新,20岁岁INSERTINTO IS_StudentVALUES(95029,赵新赵新,20);转换为对基本表的更新:转换为对基本表的更新:I

29、NSERTINTO Student(Sno,Sname,Sage,Sdept)VALUES(95029 ,赵新赵新,20,IS );2022/4/30更新视图(续)更新视图(续)例例14删除信息系学生视图删除信息系学生视图IS_Student中学号为中学号为0903129的记录的记录 DELETEFROM IS_StudentWHERE Sno= 0903129 ;转换为对基本表的更新:转换为对基本表的更新:DELETEFROM StudentWHERE Sno= 0903129 AND Sdept= IS;2022/4/30注:注:IS_Student视图的定义视图的定义CREATE VIE

30、W IS_StudentAS SELECT Sno,Sname,SageFROM StudentWHERE Sdept= ISWITH CHECK OPTION;更新视图(续)更新视图(续)v 更新视图的限制:更新视图的限制:一些视图是不可更新的一些视图是不可更新的,因为对这些视,因为对这些视图的更新不能唯一地有意义地转换成对相应基本表的更新图的更新不能唯一地有意义地转换成对相应基本表的更新例:视图例:视图S_G为不可更新视图。为不可更新视图。UPDATE S_GSET Gavg=90WHERE Sno= 0903121;这个对视图的更新无法转换成对基本表这个对视图的更新无法转换成对基本表SC

31、的更新的更新2022/4/30注:视图注:视图S_G的定义的定义CREATE VIEW S_G (Sno,Gavg)AS SELECT Sno,AVG(Grade)FROM SCGROUP BY Sno;更新视图(续)更新视图(续)v允许对允许对行列子集视图行列子集视图进行更新进行更新M从单个基本表导出,只是去掉了基本表的某些从单个基本表导出,只是去掉了基本表的某些行和列,且保留了主码的视图。行和列,且保留了主码的视图。v对其它类型视图的更新不同数据库系统有对其它类型视图的更新不同数据库系统有不同限制不同限制2022/4/303.5 3.5 视视 图图3.5.1 定义视图定义视图3.5.2 查

32、询视图查询视图3.5.3 更新视图更新视图3.5.4 视图的作用视图的作用2022/4/301. 视图能够视图能够简化简化用户的操作用户的操作 当视图中数据不是直接来自基本表时,定义视图能够简化当视图中数据不是直接来自基本表时,定义视图能够简化用户的操作用户的操作v 基于多张表连接形成的视图基于多张表连接形成的视图v 基于复杂嵌套查询的视图基于复杂嵌套查询的视图2022/4/303.5.4 3.5.4 视图的作用视图的作用2. 视图使用户能以视图使用户能以多种角度多种角度看待同一数据看待同一数据 视图机制能使视图机制能使不同用户不同用户以以不同方式不同方式看待同一数据,适应看待同一数据,适应数

33、据库共享的需要数据库共享的需要3.视图对重构数据库提供了一定程度的逻辑独立性视图对重构数据库提供了一定程度的逻辑独立性例:假设数据库逻辑结构发生改变例:假设数据库逻辑结构发生改变学生关系学生关系Student(Sno,Sname,Ssex,Sage,Sdept) “垂直垂直”地地分成两个基本表分成两个基本表: SX(Sno,Sname,Sage) SY(Sno,Ssex,Sdept)2022/4/303.视图对重构数据库提供了一定程度的逻辑独立性视图对重构数据库提供了一定程度的逻辑独立性(续续)通过建立一个视图通过建立一个视图Student:CREATE VIEW Student(Sno,Sn

34、ame,Ssex,Sage,Sdept)AS SELECT SX.Sno,SX.Sname,SY.Ssex,SX.Sage,SY.SdeptFROM SX,SYWHERE SX.Sno=SY.Sno;使用户的外模式保持不变,从而对原使用户的外模式保持不变,从而对原Student表的表的查询程序不查询程序不必修改。必修改。3.视图对重构数据库提供了一定程度的逻辑独立性视图对重构数据库提供了一定程度的逻辑独立性(续续)v 视图视图只能在一定程度上只能在一定程度上提供数据的提供数据的逻辑独立性逻辑独立性M由于对视图的更新是有条件的,因此应用程序中修改数据的语句由于对视图的更新是有条件的,因此应用程序

35、中修改数据的语句可能仍会因可能仍会因基本表结构的改变基本表结构的改变而改变。而改变。2022/4/304. 视图能够对机密数据提供安全保护视图能够对机密数据提供安全保护 对不同用户定义不同视图,使每个用户只能看到他有权看到对不同用户定义不同视图,使每个用户只能看到他有权看到的数据的数据第三章第三章 关系数据库标准语言关系数据库标准语言SQL2022/4/303.6 3.6 数据控制数据控制v概述概述v3.6.1 授权授权v3.6.2 收回权限收回权限v小结小结2022/4/30概述概述数据库系统的特点之一,由数据库系统的特点之一,由DBMSDBMS提供统一的提供统一的数据控制功能,包括:数据控

36、制功能,包括:M安全性控制安全性控制M完整性控制完整性控制M并发控制并发控制M数据库的恢复数据库的恢复2022/4/30 安全性安全性v安全性安全性:保护数据库,防止不合法的使用所造成的数:保护数据库,防止不合法的使用所造成的数据泄露和破坏。据泄露和破坏。v保证数据安全性的主要措施保证数据安全性的主要措施M存取控制:控制用户只能存取他有权存取的存取控制:控制用户只能存取他有权存取的数据数据M规定不同用户对于规定不同用户对于不同数据对象不同数据对象所允许执行的所允许执行的操作操作2022/4/30DBMS实现数据安全性保护的过程实现数据安全性保护的过程1. 用户或用户或DBA把授权决定告知系统把

37、授权决定告知系统2. GRANT和和REVOKE3. DBMS把授权的结果存入数据字典把授权的结果存入数据字典4. 当用户提出操作请求时,当用户提出操作请求时,DBMS根据根据授权定义授权定义进行检查,以决定是否执行操作请求进行检查,以决定是否执行操作请求2022/4/303.6.1 3.6.1 授授 权权vGRANT语句的一般格式:语句的一般格式:GRANT ,. ON TO ,.WITH GRANT OPTION;vGRANT功能:将功能:将指定操作对象指定操作对象的的指定操作权限指定操作权限授授予予指定的用户指定的用户。2022/4/30(1) 操作权限操作权限 对象 对象类型 操 作

38、权 限 属性列 TABLE SELECT,INSERT,UPDATE, DELETE,ALL RIVIEGES 视图 TABLE SELECT,INSERT,UPDATE, DELETE,ALL RIVIEGES 基本表 TABLE SELECT,INSERT,UPDATE, DELETE, ALTER, INDEX, ALL PRIVIEGES 数据库 DATABASE CREATETAB 2022/4/30(2) 用户的权限用户的权限v建表(建表(CREATETAB)的权限的权限:属于属于DBAvDBA授予授予-普通用户普通用户v基本表或视图的基本表或视图的属主属主拥有对该表或视图的一切拥

39、有对该表或视图的一切操作权限操作权限v接受权限的用户接受权限的用户:M一个或多个具体用户一个或多个具体用户MPUBLIC(全体用户)(全体用户)2022/4/30(4) WITH GRANT OPTION子句子句v指定了指定了WITH GRANT OPTION子句子句: 获得某种权限的用户还可以把这种权限获得某种权限的用户还可以把这种权限再授予再授予别别的用户。的用户。v没有指定没有指定WITH GRANT OPTION子句子句: 获得某种权限的用户只能使用该权限,获得某种权限的用户只能使用该权限,不能传播不能传播该权限该权限v不允许循环授权不允许循环授权2022/4/30例题例题 例例1 把

40、查询把查询Student表的权限授给用户表的权限授给用户U1 GRANT SELECT ON TABLE Student TO U1;2022/4/30例题(续)例题(续)例例2 把对把对Student表和表和Course表的全部权表的全部权限授予用户限授予用户U2和和U3 GRANT ALL PRIVILIGES ON TABLE Student, Course TO U2, U3;2022/4/30例题(续)例题(续)例例3 把对表把对表SC的查询权限授予所有用户的查询权限授予所有用户 GRANT SELECT ON TABLE SC TO PUBLIC;2022/4/30例题(续)例题(续)例例4 把查询把查询Student表和修改学生学号的权表和修改学生学号的权限授给用户限授给用户U4 GRANT UPDATE(Sno), SELECT ON TABLE Student TO U4;2022/4/30例题(续)例题(续) 例例5 把对表把对表SC的的INSERT权限授予权限授予U5用用户,并户,并允许他

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论