SQL Server数据库笔试题和答案

  • 格式:doc
  • 大小:16.50 KB
  • 文档页数:3

下载文档原格式

  / 3
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

一单词解释(2分/个) 34分

Data 数据Database 数据库RDBMS 关系数据库管理系统GRANT 授权

REVOKE 取消权限DENY 拒绝权限DECLARE 定义变量PROCEDURE存储过程

事务Transaction 触发器TRIGGER 继续continue 唯一unqiue

主键primary key 标识列identity 外键foreign key 检查check

约束constraint

二编写SQL语句(5分/题) 50分(包含笔试题问题与解答答案)

1) 创建一张学生表,包含以下信息,学号,姓名,年龄,性别,家庭住址,联系电话

Create table stu (学号int ,

姓名varchar(8),

年龄int,

性别varchar(4),

家庭地址varchar(50),

联系电话int

);

2) 修改学生表的结构,添加一列信息,学历

Alter table stu add 学历varchar(6);

3) 修改学生表的结构,删除一列信息,家庭住址

Alter table stu drop column 家庭地址

4) 向学生表添加如下信息:

学号姓名年龄性别联系电话学历

1A22男123456小学

2B21男119中学

3C23男110高中

4D18女114大学

Insert into stu values(1,’A’,22,’男’,123456,’小学’)

Insert into stu values(2,’B’,21,’男’,119,’中学’)

Insert into stu values(3,’C’,23,’男’,110,’高中’)

Insert into stu values(4,’D’,18,’女’,114,’大学’)

5) 修改学生表的数据,将电话号码以11开头的学员的学历改为“大专”

Update stu set 学历=’大专’ where 联系电话like ‘11%’

6) 删除学生表的数据,姓名以C开头,性别为‘男’的记录删除

Delect from stu where 性别=’男’ and 姓名like ‘c%’

7) 查询学生表的数据,将所有年龄小于22岁的,学历为“大专”的,学生的姓名与学号示出来Select 姓名,学号from stu where 年龄<22 and 学历=’大专’

8) 查询学生表的数据,查询所有信息,列出前25%的记录

Select top 25 percent * from stu

9) 查询出所有学生的姓名,性别,年龄降序排列

Select 姓名,性别from stu order by 年龄desc

10) 按照性别分组查询所有的平均年龄

Select avg(年龄) from stu group by 性别

三填空(3分/题) 36分(包含笔试题问题与解答答案)

1) 索引分为__聚集索引___与__非聚集索引__在一张表上最多可以创建1个聚集索引_索引。但就是可以创建_249个非聚集索引索引。

2) 系统存储过程_sp-helptext__就是用来显示规则,默认值,未加密的存储过程,用户定义函数,触发或视图的文本

3) 事务开始:begin Transction

提交事务:commit Transction

回滚事务:rollback Transction

四问答题(5分/题) 60分(包含笔试题问题与解答答案)

1) 数据库包含哪些那几种后缀名的文件必须,这些文件分别存放在什么的信息?

主要数据文件(、mdf) 包含数据用户收集的信息,还有数据库其她相关的信息,

日志数据文件(、ndf) 存放用户对数据库的增删改查的信息,用于备份恢复使用

2) TRUNCATE TABLE 命令就是什么含义?与Delete from 表名有什么区?

TRUNCATE TABLE: 提供了一种删除表中所有记录的快速方法

Delete from 表名:可以删除表的一个或多条记录

3) 说出以下聚合数的含义:avg ,sum ,max ,min , count ,count(*)

AVG:求平均值

SUM:求与

MAX:求最大值

MIN:求最小值

COUNT(*):返回所有行数

COUNT返回满足指定条件的记录值

4) inner join 就是什么意思?作用就是什么?写出基本语法结构

INNER JOIN 内联接,用于返回两个表中要查询的列数据通信

Select * from 表名1 inner join 表名2 on 条件表达式

5) 左向外联接,右向外联接,全联接的关健字如何写?

Left outer join 左向外联接

Right outer join 右向外联接

Full outer join 全联接

6) 子查询分为几类,说明相互之间的别

了查询分三种基本子查询: 1、使用in 查询返回一列或更多值

2、比较运算符,返回单个值勤做为外查询的参数

3、用exists 查询时相当于进行一次数据测试

7) 实现实体完整性,实现域完整性,实现完整性(引用完整性),实现自定义完整性分别使用什么手段?

实现实体完整性: 主键约束唯一约束标识列

实现域完整性: 默认值约束检查约束非空属性

引与完整性: 外键引用

8) 视图可以更新不?会影响到实际表不?

视图就是可以更新的,视图只就是基于基本表上的虚拟表,对视图的更新会直接影响到实际表9) 谈谈这样几个角色, dbo , Sysadmin public

Dbo : 就是数据库的拥有者,对数据库拥有所有操作的权限

Sysadmin : 可以对SQL SERVER执行任何活动

Public : 自动创建的,能捕获数据库中用户的所有默认权限

10) 何为动态游标?何为静态游标?

动态游标与静态游标相对,反映结果集中所做的所有更改,

静态游标的结果集在游标打开时,建立在tempdb中,总按照游标打开时的原样显示

11) 什么就是存储过程?为什么存储过程要比单纯的Sql 语句执行起来要快?

存储过程:就是一组预先编译好的T-SQL代码

在创建存储过程时经过了语法与性能优化,执行不必重复的步骤,使用存储过程可提高运行效率

12)什么就是Inserted 表?什么就是Deleted 表?

Inserted表用于存储inserted与update语句影响的副本

Deleted 表用于存储delect 与update语句影响的行的副本