① 求sql试题答案
1. C
2. A
3. A
4. B 说明:%是一个通配符,如select * from test where ID like 12% 这句话就表示在test表中搜索出ID以12开头的数据记录,可以是123,也可以是1234.
5. C
6. A 如果读者也作为主键你想会发生啥情况,每个人只能借1本书,灾难啊
7. A 我真的运行了一次,因为我也不确定...
8. B
9. C
10.D
11.D
12.B 这一题考的是LEFT OUTER JOIN的用法,LEFT OUTER JOIN等同于LEFT JOIN,数据数目按照较大数来算.
二.
1. ABCE D是程序员做的事
2. ABC 系统固定的角色权限是标准的PUBLIC权限,用户可以根据需要进行权限的调整,就是C选项
3. DE A错误的原因是因为事务备份的还原精度要比差异备份高,能恢复到故障点前一刻,这是差错备份做不到的;B,事务日志只能恢复从上一次备份到本次故障点之间的一个时刻.
4. AB
② SQL多项选择题,急求答案,最好有解析
1.答案A,D,E DESC是降序,省略ASC和DESC,默认为升序。
2.答案A,C,D,E 创建视图时不允许在所用SELECT语句中使用ORDER BY、COMPUTE子句
3.C,D,E 执行存储过程时可用WITH RECOMPLE选项进行重新编译;只有当执行存储过程的语句是批处理中的第一个语句,才可以直接通过名称来调用存储过程
4.C,E 使用SQL Server Management Studio不能运行命令行实用程序sqlcmd
5.C,D,F 一个局部变量只能在一个语句批中使用,使用SET语句只能对一个局部变量赋值,刚定义的局部变量的初值为空值
6.B 用户定义函数可以有输入参数和返回值
③ SQL数据统计分析问题
给你个示例脚本
declare@AAtable(yearsint,numberint)
insertinto@AAvalues(2014,45201521)
insertinto@AAvalues(2014,45201522)
insertinto@AAvalues(2014,45201523)
insertinto@AAvalues(2014,45201524)
insertinto@AAvalues(2014,45201525)
insertinto@AAvalues(2014,45201526)
insertinto@AAvalues(2014,45201527)
insertinto@AAvalues(2014,45201528)
insertinto@AAvalues(2014,45201532)
insertinto@AAvalues(2014,45201535)
insertinto@AAvalues(2014,45201536)
insertinto@AAvalues(2013,45070121)
insertinto@AAvalues(2013,45070122)
insertinto@AAvalues(2011,45010022)
insertinto@AAvalues(2011,45010023)
insertinto@AAvalues(2012,48038811)
insertinto@AAvalues(2012,48038815)
--select年份,CAST(start_numasvarchar)+'-'+CAST(end_numasvarchar)as票段号,份数from(
--selectyears年份,min(number)asstart_num,max(number)asend_num,COUNT(years)as份数
--from
--(selectyears,number,number-ROW_NUMBER()over(orderbynumber)asgrp
--from@AA)m
--groupbygrp,years)t
--wherestart_num!=end_num
--unionall
--select年份,CAST(start_numasvarchar)as票段号,份数from(
--selectyears年份,min(number)asstart_num,max(number)asend_num,COUNT(years)as份数
--from
--(selectyears,number,number-ROW_NUMBER()over(orderbynumber)asgrp
--from@AA)m
--groupbygrp,years)t
--wherestart_num=end_num
--orderby年份,票段号asc
select年份,casewhenstart_num!=end_numthenconvert(varchar(20),start_num)+'-'+convert(varchar(20),end_num)elseconvert(varchar(20),start_num)endas票段号,份数from(
selectyears年份,min(number)asstart_num,max(number)asend_num,COUNT(years)as份数
from
(selectyears,number,number-ROW_NUMBER()over(orderbynumber)asgrp
from@AA)m
groupbygrp,years)t
orderby年份,票段号asc
④ 关于SQL语句。综合分析题。急~
create database CPXS --1
/*2*/
create table 产品表(产品编号 varchar(10) not null PRIMARY KEY, 产品名称 varchar(50) not null ,库存量 int)
create table 销售商表(
客户编号 varchar(10) not null PRIMARY KEY,
客户名称 varchar(50) not null,
地区 varchar(50),
负责人 varchar(20),
电话 varchar(15)
)
create table 产品表(销售日期 datetime not null,产品编号 varchar(10) not null,数量 int,价格 money)
--3
insert into 产品表(产品编号,产品名称,库存量)
values('0001','计算机',20)
update 销售商表 set 电话='1398888888' where 客户名称='刘涛'
--5
create proc GetGoods
as
begin
select Distinct 产品名称 from 产品表
end
--第四题是什么意思
⑤ sql语句分析。(名牌大学考试题)
首先要说,这些语法都是基于SQLSERVER数据库的语法,DATEDIFF TOP等,在ORACLE等其他数据库是没有的。
1. 主要是datediff函数的用法,获取两个日期之间的时间差,可以得到年月日小时分秒等等,可以参看这个函数的说明。
这里第一个参数表示获取时间差的类型,minute表示获取两个日期的时间差是分钟。
第二个参数是起始时间,第二个是截止时间,都是datetime类型。
getdate(),获取当前时间的函数。
我觉得你这个语句写的有问题。第一,参数minute,不需要使用单引号,如果使用了单引号,参数就错误了,因为datediff第一个参数不是字符型的。
第二,datediff的函数第二个日期是开始时间,第二个是结束时间,你这个正好反了。
SQL: select * from 日程安排 where datediff(minute,f开始时间,getdate())>5
这个的意思是当前时间已经超过了开始时间5分钟的,会显示出来,而不是提前5分钟提醒。
提前五分钟提醒:SQL: select * from 日程安排 where datediff(minute,getdate(), f开始时间) < 5
距离当前时间小于5分钟的记录,才是提前5分钟提醒。
2.
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段= a.主键字段 order by a.排序字段
先看from括号内的语句:select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc,按照排序字段降序排列取出前20行数据。
然后再整体看,把表和这个20行数据关联,那么能取到的最大范围也就是这20行了。
然后取出前10行,我不知道这个为什么叫做分页查询,因为根本没有每页多少行以及第几页的参数在。这个语句就是按照排序字段倒叙排列的前20行,然后在按照排序字段正序排列从这前20行中取出前10行。实际上就是取出了按照排序字段倒叙排列的第11-20行的数据并正序排列。
3.内连接:实际上就是两表直接连接,取出连接成立的所有数据。语法使用Inner join
距离:有学生表:student : student_id , student_name
001 张三
002 李四
003 王五
成绩表: score : course_id student_id score
课程1 001 85
课程2 001 85
课程1 002 80
课程2 002 90
查询学生选课成绩,显示 student_name, course_id, score
select a.student_name, b.course_id, b.score
from student a inner join score b on a.student_id = b.student_id
查询结果 student_name, course_id, score
张三 课程1 85
张三 课程2 85
李四 课程1 80
李四 课程2 90
可以看到,直接符合连接条件的数据,都会被选择出来,而王五,因为在成绩表没有成绩,所以查询结果并没有王五的数据。
4.外连接,left join, right join,分别是左外连接和右外连接。
就是以一个表为主,而另一个表为辅。主表的数据都会被查询出来,而符合两表连接条件,那么辅表的数据就会显示,否则,为空(NULL)
还以上表和上述语句为例,查询所有学生的成绩清单,没有成绩显示空,但是学生要显示。
select a.student_name, b.course_id, b.score
from student a left join score b on a.student_id = b.student_id
查询结果:
student_name course_id score
张三 课程1 85
张三 课程2 85
李四 课程1 80
李四 课程2 90
王五 NULL NULL
可以看到,虽然连接条件王五这条并不成立,但是王五的数据一样会被显示出来,只是成绩表的相关数据位空。
有连接和左连接一样,把上面的顺序换过来,效果相同
select a.student_name, b.course_id, b.score
from score b right join student a on a.student_id = b.student_id
⑥ 几道简单的sql server 2000 习题
1.D
2.C
3.A
4.C
5.D
6.B
7.非Unicode 和 Unicode
8.错
9.错
10.对
11.对
12.对
13. INSERT ,UPDATE,DELETE
14.将一位小数四舍五入成整数