永发信息网

sql server 数据库原理及应用怎么复习

答案:1  悬赏:50  手机版
解决时间 2021-01-13 11:56
  • 提问者网友:
  • 2021-01-12 17:22
sql server 数据库原理及应用怎么复习
最佳答案
  • 五星知识达人网友:走死在岁月里
  • 2021-01-12 18:08
10. 分E-R图之间的冲突主要有属性冲突、    命名冲突     
 、结构冲突三种。  11. SQL语言集数据       定义    
 、数据     查询      
 、数据      操纵     
 、 数据_____控制______功能于一体。   12.  E-R图的主要元素是______
实体型______、____
属性________、_____
联系_______。   13. 关系系统的完整性控制包括_______实体完整性_____、__参照完整性__________、______用户定义的完整性______。  14.  关系模式R的码都为单属性,则R一定是第    

_ 范式。   15. 数据库系统一般包括数据库、_____
数据库管理系统______、______
应用系统_____、____
数据库管理员_______与用户。   16. 从关系规范化理论的角度讲,一个只满足1NF的关系可能存在的四方面问题是:数据 冗余度大、_______
插入异常_______、修改异常和删除异常。   17. 如果两个实体之间具有m:n联系,则将它们转换为关系模型的结果是_____3____个表。   18. 数据库设计的一般步骤有:需求分析、概念结构设计
 、 逻辑结构设计
 、 
物理结构设 计
 、 数据库的实施
 、运行与维护等。  19.语句 select ascii('D'), char(67) 的执行结果是:
____68_____和
___C_____。   20.语句 select lower('Beautiful') , rtrim('我心中的太阳   ') 的执行结果是:
beautiful ___和_
我心中的太阳____。   21.完整性约束包括__
实体___完整性、__
域____完整性、参照完整性和用户定义完整性。   22.在SQL Server 2008中,数据库对象包括_
表__、__视图
__、触发器、过程、列、索引、约束、规则、默认和用户自定义的数据类型等。   23.语句 select day('2004-4-6'), len('我们快放假了.') 的执行结果是:
__6___和
__7___。   24.语句 select round(13.4321,2), round(13.4567,3)的执行结果是:
__13.4300__和
____13.4570_____。<取n位小数、四舍五入>  25.事务(Transaction)可以看成是由对数据库的若干操作组成的一个单元,这些操作要么__
全部完成___,要么_
全部取消______(如果在操作执行过程中不能完成其中任一操作)。   26. SQL Server 2008 采用的身份验证模式有__Windows
身份验证___模式和__

合_模式。   27触发器定义在一个表中,当在表中执行
__insert______、
__update___或delete操作时被触发自动执行。   28.SQL Server复制有快照复制、___
事务____复制和__
合并___复制3种类型。   
     简答题  1. 说明视图与基本表的区别和联系。  答:视图是从一个或几个基本表导出的表,它与基本表不同,它是一个虚表,(2分)数据库中只存放视图的定义,而不存放视图对应的数据,这些数据存放在原来的基本表中,当基本表中的数据发生变化,从视图中查询出的数据也就随之改变(2分)。视图一经定义就可以像基本表一样被查询、删除,也可以在一个视图之上再定义新的视图,但是对视图的更新操作有限制(1分)。 2.  简述事务的特性。  答:事务具有四个特性,即ACID特性:(1分)   (1)原子性:事务中包括的所有操作要么都做,要么都不做。(1分)  (2)一致性:事务必须使数据库从一个一致性状态变到另一个一致性状态。(1分)  (3)隔离性:一个事务内部的操作及使用的数据对并发的其他事务是隔离的。(1分)  (4)持续性:事务一旦提交,对数据库的改变是永久的。(1分)  3. 试述关系模型的参照完整性规则。  答:参照完整性规则:若属性(或属性组)F是基本关系R的外码,它与基本关系S的主码Ks相对应(基本关系R和S不一定是不同的关系)(2分),则对于R中每个元组在F上的值必须为:取空值(F的每个属性值均为空值)(1.5分)或者等于S中某个元组的主码值(1.5分)。  4. 简述系统故障时的数据库恢复策略。  答:正像扫描日志文件,找出在故障发生前已经提交的事务,将其事务标识记入REDO队列,同时找出故障发生时尚未完成的事务,将其事务标识记入UNDO队列(2分);对UNDO队列中的各个事务进行撤销处理(1.5分);对REDO队列中的各个事务进行重做处理。(1.5分)   5.在SQL Server 2008中,使用视图的好处是什么? 答:  (1) 为用户集中需要的数据,简化了数据的用户操作; (2) 对用户隐藏了数据库设计的复杂性; (3) 简化用户权限的管理;  (4) 组织数据导出到其它应用程序;   6. 简述使用游标的步骤。 答:  Step1:声明游标:declare 游标名 cursor for select语句; Step2:打开游标:open 游标名;  Step3:处理数据: fetch insert delete update语句 Step4:关闭游标:close 游标名;  Step5:释放游标:deallocate 游标名;   7.简述SQL Server 2008的安全性管理机制,涉及登录账号、用户、角色以及权限分配。 答: 
   (1)计算机的连接  (2)SQL Server服务器登录(登录、固定服务器角色) (3)数据库的访问(用户/角色:固定/自定义数据库角色) (4)数据表(视图)的访问(select insert update delete) (5)存储过程/内嵌表值函数的访问(execute/select) (6)数据表(视图)中列(字段)的访问(select update)   8.  事务控制语句的使用方法是什么? 答:  begin transaction    „„               --  A组语句序列 save transaction 保存点1    „„               --  B组语句序列 if @@error <> 0     rollback transaction 保存点1    --若发生错误,回滚到”保存点1” else     commit transaction       --若没有错误,先提交A组语句,再提交B组语句。      五、设计题    现有关系数据库如下:  数据库名:学生成绩数据库  学生表(*学号,姓名,性别,民族) 课程表(*课程号,课程名称,任课教师) 成绩表(*学号,*课程号,分数)  用SQL语言实现下列功能的sql语句代码: 
1. 创建数据库[学生成绩数据库]代码(2分); create database [学生成绩数据库] go  use [学生成绩数据库] go   2. 创建[课程表]代码(2分);    课程表(课号 char(6),名称)  
   要求使用:主键(课号)、非空(名称) create table课程表(  [课程号] char(6) primary key, [课程名称] char(40) not null )    3. 创建[学生表]代码(2分); 
     学生表(学号 char(6),姓名,性别,民族)   
  要求使用:主键(学号)、默认(民族)、非空(民族,姓名)、检查(性别)  create table 学生表(  [学号] char(6) primary key, [姓名] nchar(4) not null,  [性别] nchar(1) check ([性别] in ('男', '女')), [民族] nchar(8) default '汉' not null )    4. 创建[成绩表]代码(2分);    
 成绩表(学号,课程号,分数)      要求使用:外键(成绩表.学号,成绩表.课程号)、检查(分数)  create table成绩表(  [学号] char(6) references 学生表(学号), [课程号] char(6) references 课程表(课号), [成绩] integer check ([成绩] between 0 and 100) ) 
   5. 将下列课程信息添加到课程表中  课号  课程名称 100001  大学语文    100002  大学英语   100003  西班牙语  insert 课程表 values('100001', '大学语文') insert 课程表 values('100002', '大学英语') insert 课程表 values('100003', '西班牙语')   
6. 写出创建成绩表视图(学号,姓名,课号,课程名称,成绩)的代码; create view [成绩表视图] as  select 成绩表.学号,学生表.姓名,成绩表.课程号,课程表.课程名称,成绩表.成绩  from 成绩表,学生表,课程表  where 成绩表.学号=学生表.学号 and 成绩表
.课号=课程表.课号    7. 写出创建分数存储过程用于计算某门课程成绩最高分、最低分、平均分 create procedure [分数] @课程名 nchar(16) as  select 课程名称, 最高分=max(分数)、最低分=min(分数)、平均分=avg(分数) from 成绩表视图  where 课程名称 = @课程名    8. 检索姓李的女同学的信息:姓名、性别、民族。 
  
Select 姓名,性别,民族 From 学生表  Where 姓名 like ‘李%’ and 性别=’女’    9. 定义一事务向成绩表中插入学号=‘20030021’的多条记录,并检验若该同学
成绩超过4门,则回滚事务,即成绩无效,否则成功提交。 Begin transaction    Insert 成绩表 values(‘20030021’,’001’,88);   Insert 成绩表 values(‘20030021’,’002’,99); Insert 成绩表 values(‘20030021’,’003’,77);   Insert 成绩表 values(‘20030021’,’004’,66); Declare @num int;  Set @num=(select count(*) from 成绩表 where 学号=’20030021’); If @num>4    Rollback transaction; Else    Commit transaction; Go
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯