SQL Server练习题二
一、单项选择题
1.下列关于Create Table创建数据表,叙述正确的是______。
A)必须在数据表名称中指定表所属的数据库
B)必须指明数据表的所有者
C)指定的所有者和表名称在数据库中必须唯一
D)省略表名称时,自动创建一个临时表
2.表设计器的“允许空”,用于创建字段的______约束。
A)主键 B)外键 C) CHECK D)非空
3.下列字段定义错误的是______。
A)学号varchar(16) B)人数int 4 C)产量float D)价格decimal(8,2) 4.删除数据库中已经存在的数据表test的命令是______。
A) DELETE TABLE test B) DELETE test
C) DROP TABLE test D) DROP test
5.在数据表test中增加一个字段cj(成绩)的命令是______。
A) ADD TABLE test cj int B) ADD TABLE test ALTER cj int
C) ALTER TABLE test DROP cj int D) ALTER TABLE test ADD cj int
6.在关系模式test(学号,姓名,性别,年龄)中,删除属性“年龄”的命令是______。
A) DELETE年龄FROM test B) ALTER TABLE test DROP年龄
C) UPDATE test SET年龄 D) ALTER TABLE test ADD年龄
7.在关系模式test(学号,课程名称,成绩)中,插入一条记录的正确命令是______。
A) ADD INTO test VALUES(…0001?,?高数?,?80?)
B) INSERT INTO test VALUES(…0001?,?高数?,?80?)
C) ADD INTO test VALUES(…0001?,?高数?,80)
D) INSERT INTO test VALUES(…0001?,?高数?,80)
8.在关系模式test(学号,课程名称,成绩)中,若要把“0001”的高数成绩改成85分,正确命令是______。
A) UPDATE test SET成绩=”85” WHERE学号=”0001” and课程名称=”高数”
B) UPDATE test SET成绩=85 WHERE学号=”0001” and课程名称=”高数”
C) UPDATE test SET成绩=?85? WHERE学号=?0001? and课程名称=?高数?
D) UPDATE test SET成绩=85 WHERE学号=?0001? and课程名称=?高数?9.不属于SQL Server的数据类型是______。
A)整型数据类型 B)浮点数据类型
C)通用型数据类型 D)字符数据类型
10.不属于整型数据类型的是______。
A) int B) smallint C) tinyint D) integer
11.如果数据表中某个字段只包含1~200之间的整数,则该字段最好定义为______。
A) int B) smallint C) tinyint D) bit
12.如果数据表中某个字段的数据精度要求8~12位,则该字段最好定义为______。
A) real B) smallint C) float D) money
13.某个字段的数据类型定义为decimal(12,5),则该字段有______位整数。
A) 12 B) 5 C) 6 D) 7
14.存储诸如”邮政编码”的字段类型最好定义为______。
A) Char(6) B) varChar(6) C) NChar(6) D) NvarChar(6)
15.存储诸如”通讯地址”的字段类型最好定义为______。
A) Binary(n) B) varChar(n) C) Nbianry(n) D) Ntext 16.SQL查询的HAVING子句通常出现在______子句中。
A) ORDER BY B) GROUP BY C) INDEX D) INTO
17.SELECT-SQL语句中的条件子句的关键字是______。
A) WHERE B) FROM C) ORDER BY D)GROUP BY
18.INSERT-SQL命令的功能是______。
A)在表头插入一条记录 B)在表尾插入一条记录
C)在指定位置插入一条记录 D)在指定位置插入若干记录
19.UPDATE-SQL命令的功能是______。
A)数据定义 B)数据查询
C)更新表中某些列的属性 D)修改表中的某些列的内容
20.查询命令中,限制显示记录条数的关键字是____。
A)TOP n B)DISTINCT C) ORDER D)HAVING
21.查询命令中,搜索介于两个指定值之间的所有信息的关键字是____。A)TOP n B)LIKE C) BETWEEN D)IN
22.能对某列进行平均值运算的函数是______。
A) SUM() B) AVERAGE() C) COUNT() D)AVG()
23.查询命令中,搜索与给定的列表中任意一个值相匹配的记录的关键字是____。
A)TOP n B)LIKE C) BETWEEN D)IN
24.模式匹配符号中,可匹配任意类型和长度的字符串的模式符号是____。
A) _(下划线) B) % C) [ ] D)[^ ]
25.从表中删除一条或多条记录的T-SQL命令是______。
A) DELETE B) DELETE…FROM…WHERE
C)DROP…FROM D) DELETE…TABLE…WHERE
26.对数据表的结构进行修改的命令是______。
A) MODIFY TABLE B)ALTER TABLE C)DROP TABLE D)CREATE TABLE
27.查询命令中,消除字段数据的重复值的关键字是____。
A)TOP n B)DISTINCT C) ORDER D)HAVING
28.用于统计记录个数的运算函数是______。
A) SUM() B) AVERAGE() C) COUNT() D)AVG()
29.查询命令中,搜索某字符串是否与指定的模式匹配的关键字是____。
A)TOP n B)LIKE C) BETWEEN D)IN
30.连接查询中,连接的结果是从两个表中挑选出符合连接条件的数据的连接方式是____。
A) Inner Join B)Left Join C)Right Join D)Full Join
二、填空题
1.在SQL中,create table、alter table和drop table命令分别是在数据库中、和_______基本表结构的命令。
2.向基本表插入数据时,可以在命令中使用关键字引出记录值。或者在命令中子句得到一个结果表。
3.在SQL的查询语句中,选项实现投影运算,
___________选项实现连接运算,选项实现选择运算。4.在SQL的查询语句中,选项实现分组统计功能,
选项实现对结果表的排序功能。
5.在SELECT语句的ORDERBY子句中,DESC表示按______输出;省略DESC 则按______输出。
6.在SQL SERVER中,datetime数据类型主要用来存储______和______的组合数据,其常量需要用______括起来;通常用______数据类型来表示逻辑数据。7.在SQL SERVER中,整数类型包括______、______、______和______4种,它们分别占用______、______、______和______个存储字节。
8.在SQL SERVER中,数据表的完整名称应包括______、______和______3
个部分,其中______和______可以省略。
9.SQL Server提供的双字节数据类型共有3类,分别是______、______、______。10.在SQL Server中,共使用了3种数据类型来存储二进制数据,分别是______、______、______。在对二进制数据进行插入操作时,必须在数据常量前面增加一个前缀______。
三、数据表基本操作
学生的基本情况表如下:
8.将总成绩大于200的学生的学号、数学、政治、英语等信息存入CJB中;9.从JBQK、CJB中选出“陕西省”的学生的姓名、性别、所在系部、省份、总成绩,结果按总成绩降序排列,若总成绩相同则按姓名升序排列;
10.选出与“王亚泽”同一个系的学生的姓名、性别、所在系部、平均成绩。
SQL Server练习题三
一、选择题
1. 如果将某一列设置为表的主键,则在表中此列的值()。
A)可以出现重复值 B)允许为空值
C)不允许为空值,也不能出现重复值 D)不允许为空值,但允许列值重复
2. 下面语句中,哪种语句用来修改视图()。
A)alter table B)modify view C)drop view D)alter view
3.下列标识符可以作为局部变量使用()
A) [@Myvar]B) My var C) @Myvar D) @My var
4.创建存储过程的命令为()。
A) CREATE VIEW B) CREATE INDEX
C) CREATE PROCEDURE D) CREATE FUNCTION
5.将jbqk表复制到数据表jg_tab中,正确的语句是()
A) select * from jbqk into jg_tab B) select * into jg_tab from jbqk
C) insert jg_tab from jbqk D)insert jg_tab select * from jbqk
6.print len(rtrim(str(245+100+0.5)))的显示结果是()
A) 345 B) 345.5 C) 10 D)3
7.print ascii(…12?)+len(substring(…1234?,2,2))+day(…2009-10-1?)的结果为
A)26 B) 35 C) 52 D)出错
8.计算两个日期之间的差值的函数是()
A) getdate B) dateadd C) datename D)datediff
9.产生(0,1)之间随机数的函数是()
A) sqrt() B) rnd() C) floor() D)rand()
10.判断“成绩”是否在0~100之间的约束是()
A) default B) constrain C) range D)check
二、填空题
1.在SQL Server中,编辑、运行Transact-SQL语句是在______中完成。2.Create database命令定义一个数据库,包括定义______文件和_____文件部分。
3.在查询分析器中,打开一个数据库使之成为当前库,有___种方法,其中之一使用的命令关键字为_______。
4. Select语句可以实现多个数据表连接查询,其中外连接的方式分别有______、______和______。
5. Select语句可以实现模糊查询,其模式匹配有4种,它们分别是______、______、______、______。
6. 常用的聚合函数有:计算最大值的_______,计算最小值的_______,统计总和的
_______,统计记录总数的_______和计算平均值的_______。聚合函数的计算对象不仅是列而且可以是_______。
7. SQL Server 2000的数据库管理程序分为_________和_________两部分,两部分可以安装在同一台计算机上,也可以分别安装在不同的计算机上。
8. SQL Server实例的身份验证模式有_______和_______两种。
9. 对表操作的数据定义语言(DDL)有创建表的_______语句、修改表结构的_______语句和删除表的_______语句。
10. 对表中数据更新操作的数据定义语言(DML)有添加记录的_______语句、修改记录的_______语句和删除记录的_______语句。
11. 主键是唯一能够区分表中每一行记录的_______。一个表只能有_______主键,主键不能为空值,并且可以强制表中的记录的_______。主键的标志为_______。
12. 存在两个表A和B,表A中的主键列在表B中也存在,但并不是表B的主键,仅作为表B的一个必要的属性,则称此属性为表B的_______。
13.在一个已存在数据的表中增加一列,一定要保证所增加的列允许______值。14.CHECK约束被称为________约束,UNIQUE约束被称为________约束。当一个表带有约束后,执行对表的各种_______操作时,将自动检查相应的约束,只有符合约束条件的合法操作才能被真正执行。
15.定义局部变量的语句关键字为___,局部变量的开始标记为______。16.创建和删除存储过程my_proc的命令为________和_________。17.任意写出5个常用字符函数的完整命令格式(即命令和参数)_____、_____、_____、_____、_____。
18.任意写出5个常用日期函数的完整命令格式(即命令和参数)_____、_____、_____、_____、_____。
19.select * from学生基本情况where len(rtrim(姓名))=2的功能是_____20.select ascii(str(156))+ascii(ltrim(str(200)))的结果是_____
三、综合练习
假设存在名为AAA的数据库,包括Students(学号char(8),姓名varchar(8),身份证号char(18),年龄int,专业varchar(20),入学日期DateTime)和Score(学号char(8),课程名varchar(10),成绩numeric(5,2))两张表。
一)写出下列程序段的功能。
1. DECLARE @ MyNO CHAR(8)
SET @MyNO=?40030001?
IF(SELECT专业FROM Students WHERE学号=@MyNO)=‘信息管理’ BEGIN
SELECT AVG (成绩)AS平均成绩
FROM Score
WHERE =@MyNO
END
ELSE
PRINT‘学号为’+@MyNO+‘的学生不存在或不属于信管专业’
GO
2. Declare @a numberic(5,2),@b numeric(5,2)
Set @a =(select max(成绩)from score)
Set @b=(select min (成绩)from score)
Print @a-@b
3. Declare @a char(8)
Set @a=‘计算机’
Select计算机专业人数=count(*) From students Where left(专业,3)=@a 4. Select month(入学日期)as入学月份,count(*)as人数From students
Group by month(入学日期)
5. Create procedure xxk1
@xm varchar(10)=?张?
as
select * from students x,score y
where x.学号=y.学号and姓名like @xm+?%?
go
exec xxk1
6.Create procedure xxk3
@xh1 char(2)=?2?,@xh2 char(2)=?22?
as
select学号,avg(成绩) as平均成绩 from score
where right(rtrim(学号),2) between @xh1 and @xh2
group by学号
exec xxk3 @xh2=?16?,@xh1=?6?
7.create procedure xxk5
(
@a char(8),@b varchar(10),@c numeric(5,2)
)
as
insert into score values(@a,@b,@c)
二)按下列要求写出操作命令
1.根据students、score表生成数据表xs_cj的结构,字段包括学号、姓名、入学日期、专业、课程名、成绩;
2.根据students、score表向数据表xs_cj插入“信息管理”和“电子商务”专业的学生信息;
3.修改“学号”的宽度为10,并将本专业的学号前7位改为专业的编号、第8位为1或2(随机产生)、后两位不变;
4.显示学生的学号、姓名、入学日期和专业的信息,要求入学日期按“xx年xx月xx日星期x”格式显示;
5.将“高等数学”为空的记录,修改为[60,85)之间的随机数;
6.创建视图view_xscj,包括学号、姓名、年龄、入学日期、专业、课程名、成绩;
7.查询“本专业99年入学年龄在19-25间”的学生信息;
8.查询“本专业学习成绩前5名”的学生信息;;
9.创建视图view_xscj1,包括学号、姓名、专业、总成绩、平均成绩;
10.查询各专业学习的排序情况;
11.创建存储过程按给定姓氏(默认姓“李”)查询学生的姓名、专业、总成绩、平均成绩;
12.创建存储过程统计给定专业学生的平均成绩及人数;
13.创建存储过程统计2006-2009年入学的学生的平均成绩、最高分、最低分;
14.创建视图view_stu,包括学号、姓名、年龄、入学日期、专业;
15.向students表的学号、姓名、年龄、入学日期、专业输入自己的相关信息。
三)根据实验3提供的Employees、Departments、Salary数据表,写出下列查询语句的主要功能。
1. SELECT Employees.*
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号
WHERE (Departments.部门名= '财务部')
2. SELECT Employees.*
FROM Employees INNER JOIN
WHERE (Salary.收入< 2500)
3. SELECT Employees.*
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号
WHERE (Employees.出生日期<=
(SELECT MIN(出生日期)
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号
WHERE (Departments.部门名= '研发部'))) AND (Departments.部门名= '财务部') 4. SELECT AVG(Salary.收入) AS平均收入
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号INNER JOIN
Salary ON Employees.编号= Salary.编号
WHERE (Departments.部门名= '财务部')
5. SELECT MAX(Salary.收入) AS最高收入, MIN(Salary.收入) AS最低收入
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号INNER JOIN
Salary ON Employees.编号= Salary.编号
WHERE (Departments.部门名= '财务部')
6. SELECT AVG(Salary.收入-Salary.支出) AS实际平均收入
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号INNER JOIN
Salary ON Employees.编号= Salary.编号
WHERE (Departments.部门名= '财务部')
7. SELECT COUNT(Employees.编号) AS总人数
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号
WHERE (Departments.部门名= '财务部')
8. SELECT COUNT(Employees.编号) AS总人数
FROM Employees INNER JOIN
Departments ON Employees.部门号= Departments.部门号INNER JOIN
Salary ON Employees.编号= Salary.编号
WHERE (Departments.部门名= '财务部') AND (Salary.收入> 2500)
9. SELECT Employees.*, Salary.收入
FROM Employees INNER JOIN
ORDER BY Salary.收入DESC
10. SELECT Departments.部门名, AVG(Salary.收入) AS平均, MAX(Salary.收入) AS最高,
MIN(Salary.收入) AS最低, COUNT(*) AS人数
FROM Employees INNER JOIN
Salary ON Employees.编号= Salary.编号INNER JOIN
Departments ON Employees.部门号= Departments.部门号
GROUP BY Departments.部门名
ORDER BY COUNT(*)
四、程序改错
建立jbqk数据表结构并满足完整性的要求是:学号必须输入,且为主键;“姓名”必须输入;“性别”必须输入“男”或“女”;出生日期为1985-2009之间,所属单位为“管理学院”和“能源学院”;专业的默认值为“信息管理”;各门课程的成绩必须在0-100之间。建立该数据表结构的其T-SQL语句如下,修改其中的错误。
CREATE DATABASE JBQK --FOUND ERROR 1--
(学号char (8) PK_xh NOT NULL PRIMARY KEY, --FOUND ERROR 2--姓名nchar (4) IS NULL , --FOUND ERROR 3--
性别nchar (1) CONSTRAINT chk_xb性别=?男女?, --FOUND ERROR 4--出生日期datetime CONSTRAINT CK_rq check(出生日期between 1985 and 2008) , --FOUND ERROR 5--
所属单位char (16) in(…管理学院?,?能源学院?), --FOUND ERROR 6--
专业char (20) default …信息管理? for专业, --FOUND ERROR 7--
数学decimal(4, 1) CHECK (数学= [0-100]) , --FOUND ERROR 8--
语文decimal(4, 1) CHECK (语文Not NULL) , --FOUND ERROR 9--
英语decimal(4, 1) CHECK (0<=英语<= 100) , --FOUND ERROR 10--
备注text )