TR 

解决方案 »

  1.   

    csdn这里的帖子那一个都可能成为试题
      

  2.   

    练习题一create database mydb
    go
    use mydb
    create table student
    (
    --学号
    sno varchar(3) not null primary key,
    --姓名
    sname varchar(4) not null,
    --性别
    ssex varchar(2) not null,
    --出生年月
    sbirthday datetime,
    --所在班级
    class varchar(5)
    )
    create table teacher
    (
    --教工编号
    tno varchar(3) not null primary key,
    --教工姓名
    tname varchar(4) not null,
    --教工性别
    tsex varchar(2) not null,
    --教工出生日期
    tbirthday datetime,
    --职称
    prof varchar(6),
    --所在部门
    depart varchar(10)
    )create table course
    (
    --课程号
    cno varchar(5) not null primary key,
    --课程名称
    cname varchar(10) not null,
    --教工编号
    tno varchar(3) references teacher(tno)
    )create table score
    (
    --学号
    sno varchar(3) not null references student(sno),
    --课程号
    cno varchar(5) not null references course(cno),
    --成绩
    degree decimal(4,1)
    )
    insert into student
    values('108','曾华','男','1977-09-01','95033')insert into student
    values('105','匡明','男','1975-10-02','95031')insert into student
    values('107','王丽','女','1976-01-23','95033')insert into student
    values('101','李军','男','1976-02-20','95033')insert into student
    values('109','王芳','女','1975-02-10','95031')insert into student
    values('103','陆君','男','1974-06-03','95031')insert into teacher
    values('804','李诚','男','1958-12-02','副教授','计算机系')
    insert into teacher
    values('856','张旭','男','1969-03-12','讲师','电子工程系')
    insert into teacher
    values('825','王萍','女','1972-05-05','助教','计算机系')
    insert into teacher
    values('831','刘冰','女','1958-08-14','助教','电子工程系')insert into course
    values('3-105','计算机导论','825')
    insert into course
    values('3-245','操作系统','804')
    insert into course
    values('6-166','数字电路','856')
    insert into course
    values('9-888','高等数学','831')
    insert into score
    values('103','3-245','86')
    insert into score
    values('105','3-245','75')
    insert into score
    values('109','3-245','68')
    insert into score
    values('103','3-105','92')
    insert into score
    values('105','3-105','88')
    insert into score
    values('109','3-105','76')
    insert into score
    values('101','3-105','64')
    insert into score
    values('107','3-105','91')
    insert into score
    values('108','3-105','78')
    insert into score
    values('101','6-166','85')
    insert into score
    values('107','6-166','79')
    insert into score
    values('108','6-166','81')select * from student
    select * from teacher
    select * from course
    select * from score--1、 查询Student表中的所有记录的Sname、Ssex和Class列。
    --2、 查询教师所有的单位即不重复的Depart列。
    --3、 查询Student表的所有记录。
    --4、 查询Score表中成绩在60到80之间的所有记录。
    --5、 查询Score表中成绩为85,86或88的记录。
    --6、 查询Student表中“95031”班或性别为“女”的同学记录。
    --7、 以Class降序查询Student表的所有记录。
    --8、 以Cno升序、Degree降序查询Score表的所有记录。
    --9、 查询“95031”班的学生人数。
    --10、查询Score表中的最高分的学生学号和课程号。
    --11、查询‘3-105’号课程的平均分。
    --12、查询Score表中至少有5名学生选修的并以3开头的课程的平均分数。
    --13、查询最低分大于70,最高分小于90的Sno列。
    --14、查询所有学生的Sname、Cno和Degree列。
    --15、查询所有学生的Sno、Cname和Degree列。
    --16、查询所有学生的Sname、Cname和Degree列。
    --17、查询“95033”班所选课程的平均分。
    --18、假设使用如下命令建立了一个grade表:
    --create table grade(low int,upp int,rank varchar(1))
    --insert into grade values(90,100,'A')
    --insert into grade values(80,89,'B')
    --insert into grade values(70,79,'C')
    --insert into grade values(60,69,'D')
    --insert into grade values(0,59,'E')
    --现查询所有同学的Sno、Cno和rank列。
    --19、查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录。//无关子查询
    --20、查询score中选学多门课程的同学中分数为非最高分成绩的记录。
    --21、查询成绩高于学号为“109”、课程号为“3-105”的成绩的所有记录。
    --22、查询和学号为108的同学同年出生的所有学生的Sno、Sname和Sbirthday列。
    --23、查询“张旭“教师任课的学生成绩。
    --24、查询选修某课程的同学人数多于5人的教师姓名。
    --25、查询95033班和95031班全体学生的记录。
    --26、查询存在有85分以上成绩的课程Cno.
    --27、查询出“计算机系“教师所教课程的成绩表。
    --28、查询“计算机系”与“电子工程系“不同职称的教师的Tname和Prof。
    --29、查询选修编号为“3-105“课程且成绩至少高于选修编号为“3-245”的同学的Cno、Sno和Degree,并按Degree从高到低次序排序。
    --30、查询选修编号为“3-105”且成绩高于选修编号为“3-245”课程的同学的Cno、Sno和Degree.
    --31、查询所有教师和同学的name、sex和birthday.
    --32、查询所有“女”教师和“女”同学的name、sex和birthday.
    --33、查询成绩比该课程平均成绩低的同学的成绩表。
    --34、查询所有任课教师的Tname和Depart.
    --35 查询所有未讲课的教师的Tname和Depart. 
    --36、查询至少有2名男生的班号。
    --37、查询Student表中不姓“王”的同学记录。
    --38、查询Student表中每个学生的姓名和年龄。
    --39、查询Student表中最大和最小的Sbirthday日期值。
    --40、以班号和年龄从大到小的顺序查询Student表中的全部记录。
    --41、查询“男”教师及其所上的课程。
    --42、查询最高分同学的Sno、Cno和Degree列。
    --43、查询和“李军”同性别的所有同学的Sname.
    --44、查询和“李军”同性别并同班的同学Sname.
    --45、查询所有选修“计算机导论”课程的“男”同学的成绩表。
    --46、查询score表中分数最高的学生的信息。//多层嵌套
    --47、查询score表中的平均分在80分以上的学生信息。//相关查询。无关查询练习题二创建以下三个表:    学生表: Student(Sno,Sname,Ssex,Sbirthday,Sage,Sdept)
                Student 由学号 (Sno)、姓名 (Sname)、性别 (Ssex)、出生日期 (Sbirthday)、年龄 (Sage), 
                所在系 (Sdept) 五个属性组成,其中 Sno 为主键.    课程表: Coures(Cno,Cname,Cpno,Ccredit)
                Coures 由课程号 (Cno)、课程名 (Cname)、选修课号 (Cpno)、学分 (Ccredit) 四个属性组成, 
                其中 Cno 为主键.    学生选课表: SC(Sno,Cno,Grade)
                    SC 由学号 (Sno)、 课程号 (Cno)、 成绩 (Grade) 三个属性组成, 主键为 (Sno,Cno).按照以上三个表来做如下的习题:1.查找全体学生的学号与姓名2.查找全体学生的姓名、学号与所在系3.查找全体学生的详细纪录4.查找全体学生的姓名和其出生日期 5.查找全体学生的姓名、出生日期和所有系,要求用小写字母表示所有系名6.查找全体学生的姓名、出生日期和所有系,要求给这几列起别名7.查找选修了课程的学生学号(不能重复)8.查找计算系全体学生的名单9.查找所有年龄在20岁以下的学生姓名和其年龄(2种做法)10.查找考试成绩有不及格的学生的学号(不能重复)11.查找年龄在20--30岁(包括20岁和23岁)之间的学生的姓名、系别和年龄12.查找年龄不在20--30岁(包括20岁和23岁)之间的学生的姓名、系别和年龄13.查找信息系、数学系和计算机系学生的姓名与性别(用in做)14.查找不是信息系、数学系,也不是计算机系的学生的姓名与性别(用not in做)15.查找学号以为95001开头的学生的详细情况(用2种方法做)16.查找所有以“刘”开头的学生的姓名、学号和性别17.查找以“欧阳”开头的且三个汉字的学生的姓名18.查找名字中第2个字为“阳”字的学生的姓名和学号19.查找所有不以“刘”开头的学生姓名20.查找以“C”开头的课程的课程号和学分21.查找以“H”开头,且倒数第三个字符为“T”的课程的课程号和学分22.某些学生选修课程后没有参加考试,所以有选课纪录,但没有考试成绩。查找缺少成绩的学生的学号和相应
       的课程号23.查找除了无成绩的学生的学号和课程号24.查找计算机系年龄在20岁以下的学生姓名25.查找是计算机系 或者是 数学系 或者是 信息系的学生姓名和性别26.查找选修了3号课程的学生的学号与其成绩,其查找结果按分数的降序排列27.查找全体学生情况,查找结果按所在系的系号升序排列,同一系中的学生按年龄降序排列28.查找学生总人数29.查找选修了课程的学生人数30.计算1号课程的学生平均成绩
      

  3.   

    问题描述:
    为管理岗位业务培训信息,建立3个表:
    S (S#,SN,SD,SA)   S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄
    C (C#,CN )        C#,CN       分别代表课程编号、课程名称
    SC ( S#,C#,G )    S#,C#,G     分别代表学号、所选修的课程编号、学习成绩要求实现如下6个处理:
      1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名
      2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位
      3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位
      4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位
      5. 查询选修了课程的学员人数
      6. 查询选修课程超过5门的学员学号和所属单位1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名 
    --实现代码:
    SELECT SN,SD FROM S
    WHERE [S#] IN(
        SELECT [S#] FROM C,SC
        WHERE C.[C#]=SC.[C#]
            AND CN=N'税收基础')
    2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位
    --实现代码:
    SELECT S.SN,S.SD FROM S,SC
    WHERE S.[S#]=SC.[S#]
        AND SC.[C#]='C2'3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位
    --实现代码:
    SELECT SN,SD FROM S
    WHERE [S#] NOT IN(
        SELECT [S#] FROM SC 
        WHERE [C#]='C5')4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位
    --实现代码:
    SELECT SN,SD FROM S
    WHERE [S#] IN(
        SELECT [S#] FROM SC 
            RIGHT JOIN C ON SC.[C#]=C.[C#]
        GROUP BY [S#]
        HAVING COUNT(*)=COUNT(DISTINCT [S#]))5. 查询选修了课程的学员人数
    --实现代码:
    SELECT 学员人数=COUNT(DISTINCT [S#]) FROM SC6. 查询选修课程超过5门的学员学号和所属单位
    --实现代码:
    SELECT SN,SD FROM S
    WHERE [S#] IN(
        SELECT [S#] FROM SC 
        GROUP BY [S#]
        HAVING COUNT(DISTINCT [C#])>5)问题描述:
    已知关系模式:
    S (SNO,SNAME)           学生关系。SNO 为学号,SNAME 为姓名
    C (CNO,CNAME,CTEACHER)  课程关系。CNO 为课程号,CNAME 为课程名,CTEACHER 为任课教师
    SC(SNO,CNO,SCGRADE)     选课关系。SCGRADE 为成绩要求实现如下5个处理:
      1. 找出没有选修过“李明”老师讲授课程的所有学生姓名
      2. 列出有二门以上(含两门)不及格课程的学生姓名及其平均成绩
      3. 列出既学过“1”号课程,又学过“2”号课程的所有学生姓名
      4. 列出“1”号课成绩比“2”号同学该门课成绩高的所有学生的学号
      5. 列出“1”号课成绩比“2”号课成绩高的所有学生的学号及其“1”号课和“2”号课的成绩1. 找出没有选修过“李明”老师讲授课程的所有学生姓名
    --实现代码:
    SELECT SNAME FROM S
    WHERE NOT EXISTS(
        SELECT * FROM SC,C
        WHERE SC.CNO=C.CNO 
             AND C.CTEACHER='李明'
              AND SC.SNO=S.SNO)2. 列出有二门以上(含两门)不及格课程的学生姓名及其平均成绩
    --实现代码:
    SELECT S.SNO,S.SNAME,AVG_SCGRADE=AVG(SC.SCGRADE)
    FROM S,SC,(
        SELECT SNO
        FROM SC
        WHERE SCGRADE<60
        GROUP BY SNO
        HAVING COUNT(DISTINCT CNO)>=2
    )A WHERE S.SNO=A.SNO AND SC.SNO=A.SNO
    GROUP BY S.SNO,S.SNAME3. 列出既学过“1”号课程,又学过“2”号课程的所有学生姓名
    --实现代码:
    SELECT S.SNO,S.SNAME
    FROM S,(
        SELECT SC.SNO
        FROM SC,C
        WHERE SC.CNO=C.CNO
            AND C.CNAME IN('1','2')
        GROUP BY SNO
        HAVING COUNT(DISTINCT CNO)=2
    )SC WHERE S.SNO=SC.SNO 4. 列出“1”号课成绩比“2”号同学该门课成绩高的所有学生的学号
    --实现代码:
    SELECT S.SNO,S.SNAME
    FROM S,SC SC1,SC SC2
        WHERE SC1.CNO='1'
            AND SC2.SNO='2'
            AND SC1.CNO=S.CNO
            AND SC1.SCGRADE>SC2.SCGRADE5. 列出“1”号课成绩比“2”号课成绩高的所有学生的学号及其“1”号课和“2”号课的成绩
    --实现代码:
    SELECT SC1.SNO,[1号课成绩]=SC1.SCGRADE,[2号课成绩]=SC2.SCGRADE
    FROM SC SC1,SC SC2
    WHERE SC1.CNO='1'
            AND SC2.CNO='2'
            AND SC1.SNO=SC2.SNO
            AND SC1.SCGRADE>SC2.SCGRADE
      

  4.   

    问题描述:
    本题用到下面三个关系表:
    CARD     借书卡。   CNO 卡号,NAME  姓名,CLASS 班级
    BOOKS    图书。     BNO 书号,BNAME 书名,AUTHOR 作者,PRICE 单价,QUANTITY 库存册数 
    BORROW   借书记录。 CNO 借书卡号,BNO 书号,RDATE 还书日期
    备注:限定每人每种书只能借一本;库存册数随借书、还书而改变。
    要求实现如下15个处理:
      1. 写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束。
      2. 找出借书超过5本的读者,输出借书卡号及所借图书册数。
      3. 查询借阅了"水浒"一书的读者,输出姓名及班级。
      4. 查询过期未还图书,输出借阅者(卡号)、书号及还书日期。
      5. 查询书名包括"网络"关键词的图书,输出书号、书名、作者。
      6. 查询现有图书中价格最高的图书,输出书名及作者。
      7. 查询当前借了"计算方法"但没有借"计算方法习题集"的读者,输出其借书卡号,并按卡号降序排序输出。
      8. 将"C01"班同学所借图书的还期都延长一周。
      9. 从BOOKS表中删除当前无人借阅的图书记录。
      10.如果经常按书名查询图书信息,请建立合适的索引。
      11.在BORROW表上建立一个触发器,完成如下功能:如果读者借阅的书名是"数据库技术及应用",就将该读者的借阅记录保存在BORROW_SAVE表中(注ORROW_SAVE表结构同BORROW表)。
      12.建立一个视图,显示"力01"班学生的借书信息(只要求显示姓名和书名)。
      13.查询当前同时借有"计算方法"和"组合数学"两本书的读者,输出其借书卡号,并按卡号升序排序输出。
      14.假定在建BOOKS表时没有定义主码,写出为BOOKS表追加定义主码的语句。
      15.对CARD表做如下修改:
        a. 将NAME最大列宽增加到10个字符(假定原为6个字符)。
        b. 为该表增加1列NAME(系名),可变长,最大20个字符。
    1. 写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束
    --实现代码:
    CREATE TABLE BORROW(
        CNO int FOREIGN KEY REFERENCES CARD(CNO),
        BNO int FOREIGN KEY REFERENCES BOOKS(BNO),
        RDATE datetime,
        PRIMARY KEY(CNO,BNO)) 2. 找出借书超过5本的读者,输出借书卡号及所借图书册数
    --实现代码:
    SELECT CNO,借图书册数=COUNT(*)
    FROM BORROW
    GROUP BY CNO
    HAVING COUNT(*)>53. 查询借阅了"水浒"一书的读者,输出姓名及班级
    --实现代码:
    SELECT * FROM CARD c
    WHERE EXISTS(
        SELECT * FROM BORROW a,BOOKS b 
        WHERE a.BNO=b.BNO
            AND b.BNAME=N'水浒'
            AND a.CNO=c.CNO) 4. 查询过期未还图书,输出借阅者(卡号)、书号及还书日期
    --实现代码:
    SELECT * FROM BORROW 
    WHERE RDATE<GETDATE() 5. 查询书名包括"网络"关键词的图书,输出书号、书名、作者
    --实现代码:
    SELECT BNO,BNAME,AUTHOR FROM BOOKS
    WHERE BNAME LIKE N'%网络%' 6. 查询现有图书中价格最高的图书,输出书名及作者
    --实现代码:
    SELECT BNO,BNAME,AUTHOR FROM BOOKS
    WHERE PRICE=(
        SELECT MAX(PRICE) FROM BOOKS) 7. 查询当前借了"计算方法"但没有借"计算方法习题集"的读者,输出其借书卡号,并按卡号降序排序输出
    --实现代码:
    SELECT a.CNO
    FROM BORROW a,BOOKS b
    WHERE a.BNO=b.BNO AND b.BNAME=N'计算方法'
        AND NOT EXISTS(
            SELECT * FROM BORROW aa,BOOKS bb
            WHERE aa.BNO=bb.BNO
                AND bb.BNAME=N'计算方法习题集'
                AND aa.CNO=a.CNO)
    ORDER BY a.CNO DESC 8. 将"C01"班同学所借图书的还期都延长一周
    --实现代码:
    UPDATE b SET RDATE=DATEADD(Day,7,b.RDATE)
    FROM CARD a,BORROW b
    WHERE a.CNO=b.CNO
        AND a.CLASS=N'C01' 9. 从BOOKS表中删除当前无人借阅的图书记录
    --实现代码:
    DELETE A FROM BOOKS a
    WHERE NOT EXISTS(
        SELECT * FROM BORROW
        WHERE BNO=a.BNO) 10. 如果经常按书名查询图书信息,请建立合适的索引
    --实现代码:
    CREATE CLUSTERED INDEX IDX_BOOKS_BNAME ON BOOKS(BNAME)11. 在BORROW表上建立一个触发器,完成如下功能:如果读者借阅的书名是"数据库技术及应用",就将该读者的借阅记录保存在BORROW_SAVE表中(注ORROW_SAVE表结构同BORROW表)
    --实现代码:
    CREATE TRIGGER TR_SAVE ON BORROW
    FOR INSERT,UPDATE
    AS
    IF @@ROWCOUNT>0
    INSERT BORROW_SAVE SELECT i.*
    FROM INSERTED i,BOOKS b
    WHERE i.BNO=b.BNO
        AND b.BNAME=N'数据库技术及应用' 12. 建立一个视图,显示"力01"班学生的借书信息(只要求显示姓名和书名)
    --实现代码:
    CREATE VIEW V_VIEW
    AS
    SELECT a.NAME,b.BNAME
    FROM BORROW ab,CARD a,BOOKS b
    WHERE ab.CNO=a.CNO
        AND ab.BNO=b.BNO
        AND a.CLASS=N'力01'13. 查询当前同时借有"计算方法"和"组合数学"两本书的读者,输出其借书卡号,并按卡号升序排序输出
    --实现代码:
    SELECT a.CNO
    FROM BORROW a,BOOKS b
    WHERE a.BNO=b.BNO
        AND b.BNAME IN(N'计算方法',N'组合数学')
    GROUP BY a.CNO
    HAVING COUNT(*)=2
    ORDER BY a.CNO DESC 14. 假定在建BOOKS表时没有定义主码,写出为BOOKS表追加定义主码的语句
    --实现代码:
    ALTER TABLE BOOKS ADD PRIMARY KEY(BNO) 15.1 将NAME最大列宽增加到10个字符(假定原为6个字符)
    --实现代码:
    ALTER TABLE CARD ALTER COLUMN NAME varchar(10) 15.2 为该表增加1列NAME(系名),可变长,最大20个字符
    --实现代码:
    ALTER TABLE CARD ADD 系名 varchar(20)