Demon521

Troubleshooting. Good luck to me 2009! 人生中没有Ctrl+Z!
  博客园  :: 首页  :: 联系 :: 订阅 订阅  :: 管理

Summary SQL

Posted on 2008-12-25 09:59  Demon521  阅读(286)  评论(0编辑  收藏  举报
 

Summary SQL

S QL查询语句精华使用简要

一、 简单查询

简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。它们分别说明所查询列、查询的

表或视图、以及搜索条件等。例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。

SELECT nickname,email

FROM testtable

WHERE name='张三'

  () 选择列表

  选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变量和全局变量)等构成。

  1、选择所有列

  例如,下面语句显示testtable表中所有列的数据:

SELECT *

FROM testtable

  2、选择部分列并指定它们的显示次序查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。

  例如:

SELECT nickname,email

  FROM testtable

  3、更改列标题

  在选择列表中,可重新指定列标题。定义格式为:

列标题=列名

列名 列标题如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列标题:

SELECT 昵称=nickname,电子邮件=email

FROM testtable

  4、删除重复行

SELECT语句中使用ALLDISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认

ALL。使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。

  5、限制返回的行数

使用TOP n [PERCENT]选项限制返回的数据行数,TOP n说明返回n行,而TOP n PERCENT时,说明n

表示一百分数,指定返回的行数等于总行数的百分之几。

例如:

SELECT TOP 2 *

FROM testtable

SELECT TOP 20 PERCENT *

FROM testtable

  ()FROM子句

FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图,它们之间用逗号分隔。在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列

所属的表或视图。例如在usertablecitytable表中同时存在cityid列,在查询两个表中的cityid时应

使用下面语句格式加以限定:

SELECT username,citytable.cityid

FROM usertable,citytable

WHERE usertable.cityid=citytable.cityid

FROM子句中可用以下两种格式为表或视图指定别名:

表名 as 别名

表名 别名

  () FROM子句

FROM子句指定SELECT语句查询及与查询相关的表或视图。在FROM子句中最多可指定256个表或视图,它们之间用逗号分隔。在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列

所属的表或视图。例如在usertablecitytable表中同时存在cityid列,在查询两个表中的cityid时应使用下面语句格式加以限定:

SELECT username,citytable.cityid

FROM usertable,citytable

WHERE usertable.cityid=citytable.cityid

FROM子句中可用以下两种格式为表或视图指定别名:

表名 as 别名

表名 别名

例如上面语句可用表的别名格式表示为:

SELECT username,b.cityid

FROM usertable a,citytable b

WHERE a.cityid=b.cityid

SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。

例如:

SELECT a.au_fname+a.au_lname

FROM authors a,titleauthor ta

(SELECT title_id,title

FROM titles

WHERE ytd_sales>10000

) AS t

WHERE a.au_id=ta.au_id

AND ta.title_id=t.title_id

此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。

  () 使用WHERE子句设置查询条件

WHERE子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20的数据:

SELECT *

FROM usertable

WHERE age>20

WHERE子句可包括各种条件运算符:

比较运算符(大小比较)>>==<<=<>!>!<

范围运算符(表达式值是否在指定的范围)BETWEENAND

NOT BETWEEN…AND…

列表运算符(判断表达式是否为列表中的指定项)IN (1,2……)

NOT IN (1,2……)

模式匹配符(判断值是否与指定的字符通配格式相符):LIKENOT LIKE

空值判断符(判断表达式是否为空)IS NULLNOT IS NULL

逻辑运算符(用于多条件的逻辑连接)NOTANDOR

1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=30

2、列表运算符例:country IN ('Germany','China')

3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。可用于char

varchartextntextdatetimesmalldatetime等类型查询。

可使用以下通配字符:

百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%

下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。

方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。

[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。

例如:

限制以Publishing结尾,使用LIKE '%Publishing'

限制以A开头:LIKE '[A]%'

限制以A开头外:LIKE '[^A]%'

4、空值判断符例WHERE age IS NULL

5、逻辑运算符:优先级为NOTANDOR

()查询结果排序

使用ORDER BY子句对查询返回的结果按一列或多列排序。ORDER BY子句的语法格式为:

ORDER BY {column_name [ASC|DESC]} [,…n]

其中ASC表示升序,为默认值,DESC为降序。ORDER BY不能按ntexttextimage数据类型进行排

序。

例如:

SELECT *

FROM usertable

ORDER BY age desc,userid ASC

另外,可以根据表达式进行排序。

  二、 联合查询

UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联

合查询。UNION的语法格式为:

select_statement

UNION [ALL] selectstatement

[UNION [ALL] selectstatement][…n]

其中selectstatement为待联合的SELECT查询语句。

ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一行。联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类

型,系统将低精度的数据类型转换为高精度的数据类型。在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如:

查询1 UNION (查询2 UNION 查询3)

  三、连接查询通过连接运算符可以实现多个表查询。连接是关系数据库模型的主要特点,也是它区别于其它类型

数据库管理系统的一个标志。

在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在一个表中。当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。连接操作给用户带

来很大的灵活性,他们可以在任何时候增加新的数据类型。为不同实体创建新的表,尔后通过连接进行

查询。

连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于

将连接操作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。

SQL-92标准所定义的FROM子句的连接语法格式为:

FROM join_table join_type join_table

[ON (join_condition)]

其中join_table指出参与连接操作的表名,连接可以对同一个表操作,也可以对多表操作,对同一

个表操作的连接又称做自连接。

join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。内连接(INNER JOIN)使用比

较运算符进行表间某()列数据的比较操作,并列出这些表中与连接条件相匹配的数据行。根据所使用

的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。

外连接分为左外连接(LEFT OUTER JOINLEFT JOIN)、右外连接(RIGHT OUTER JOINRIGHT JOIN)

和全外连接(FULL OUTER JOINFULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹

配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的

数据行。

交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的

数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

连接操作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑

运算符等构成。

无论哪种连接都不能对textntextimage数据类型列进行直接连接,但可以对这三种列进行间接

连接。例如:

SELECT p1.pub_id,p2.pub_id,p1.pr_info

FROM pub_info AS p1 INNER JOIN pub_info AS p2

ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)

  ()内连接

内连接查询操作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分

三种:

1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接

表中的所有列,包括其中的重复列。

2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些

运算符包括>>=<=<!>!<<>

3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询

结果集合中所包括的列,并删除连接表中的重复列。

例,下面使用等值连接列出authorspublishers表中位于同一城市的作者和出版社:

SELECT *

FROM authors AS a INNER JOIN publishers AS p

ON a.city=p.city

又如使用自然连接,在选择列表中删除authors publishers 表中重复列(citystate)

SELECT a.*,p.pub_id,p.pub_name,p.country

FROM authors AS a INNER JOIN publishers AS p

ON a.city=p.city

()外连接

内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件

的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外

连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。

如下面使用左外连接将论坛内容和作者信息连接起来:

SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b

ON a.username=b.username

下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市:

SELECT a.*,b.*

FROM city as a FULL OUTER JOIN user as b

ON a.username=b.username

  ()交叉连接

交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数

据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等

6*8=48行。

SELECT type,pub_name

FROM titles CROSS JOIN publishers

ORDER BY type

 

SQL查询语句复习题

SQL查询语句复习题

新建学生-课程数据库的三个表:

学生表:Student(Sno,Sname,Ssex,Sage,Sdept) Sno为主码;

课程表:Course(Cno,Cname,Cpno,Credeit) Cno为主码;

学生选修表:SC(Sno,Cno,Grade) Sno,Cno,为主码;

Student

学号

 Sno姓名

Sname性别

Ssex年龄

Sage所在系

Sdept

95001李勇男20CS

95002刘晨女19IS

95003王敏女18MA

95004张立男19IS

 

课程号

Sno课程名

Cname先行课

Cpno学分

Credit

1数据库54

2数学2

3信息系统14

4操作系统63

5数据结构74

6数据处理2

7Pascal语言64

Course:

 

SC:

学号

Sno课程号

Cno成绩

Grade

95001192

95001285

95001388

95002290

95002380:查询表中的列和行

1:查询全体学生的学与姓名

sele sno,sname from student

2:查询全体学生的姓名、学号、所在系。

sele sno,sname,sdept from student

3:查询全体学生的详细记录

sele * from student

4:查询全体学生的姓名及出生年份

sele sno,sage from student

5:查询全体学生的姓名,出生年份及所在系,要用小写字母表示系名

 

6:查询选修了课程的学生学号

sele sno,cno from sc

7:查询选修了课程的学生姓名

sele distinct sname from student,sc where student.sno=sc.sno

:条件查询:

常用的查询条件查询条件谓词

比较=,<,>,>=,<=,!=,<>,!>,!<;

not+上述比较运算符

确定范围Between and,Not between And,

确定集合IN,not IN

字符匹配Like,Not Like

空值IsNull,ISNOTNULL

多重条件AND,OR

1:查询计算机系全体学生的姓名

sele sname from student where sdept=”CS”

2:查询所有年龄在20岁以下的学生姓名及其年龄

sele sname,sage from student where sage<20

3:查询考试成绩有不及格的学生的学号

sele student.sno from student,sc where student.sno=sc.sno and grade<60

4:查询年龄在2023间的学生的姓名,系别及年龄

sele sname,sdept,sage from student where sage between 20 and 23

5: 查询年龄不在2023间的学生的姓名,系别及年龄

sele sname,sdept,sage from student where sage not between 20 and 23

6:查询信息系(IS),数学系(MA)和计算机系(CS)学生的姓名和性别

sele sname,ssex from student where sdept in("IS","MA","CS")

7:查询不是信息系(IS),数学系(MA)和计算机系(CS)学生的姓名和性别

sele sname,ssex from student where sdept not in("IS","MA","CS")

8:查询学号为”95001”的学生详细情况

sele * from student where sno=95001

9:查询所有姓刘的学生的姓名,学号和性别(where name like ‘刘%)

sele sname,sno,ssex from student where sname like '%'

10:查询姓”欧阳”且命名为三个汉字的学生的姓名

sele sname from student where sname like '欧阳_'

11:查询名字中第2个字为”阳”字的学生姓名和学号(where sname like _ _%)

sele sname,sno from student where sname like '_ _%'

12:查询所有不姓刘的学生姓名

sele sname from student where sname not like '%'

13:查询DB_Design课程的课程号和学分(where cname like Db"_DesignEscape")

sele cno,gredit from course where cname like ‘Db"_Design’Escape’"’

14:查询以”DB_”开头,且倒数第3个字符为i的课程的详细情况(where cname like DB"_%i__escape")

DB"_%i__’escape’"’) sele cno,gredit from course where cname like ‘Db"_%i__’escape’"’

 

15:查询缺少成绩的学生的学号和相应的课程号

sele student.sno,cno from student,sc where grade is null

16:查询所有成绩的学生学号和课程号(where grade is not null)

sele student.sno,cno from student,sc where grade is not null

17:查询计算机系年龄在20岁以下的学生姓名

sele sname from student where sdept=”CS” and sage<20

18:查询选修了3号课程的学生的学号及其成绩,分数降序排列

sele student.sno,grade from student,sc where student.sno=sc.sno and sc.cno=3 order by grade desc

 

19:查询全体学生情况,结果按所在系的号升序排列,同一系中的学生按年龄降序

sele * from student order by sdept,sage desc

 

:使用集函数

count,sum,avg,max,min

1:查询学生的总人数

2:查询选修了课程的学生人数(select count(distinct sno))

3:计算1号课程的学生平均成绩

4:查询选修1号课程的学生最高分数

5:求各个课程号及相应的选课人数( selsect cno,count (sno); from sc; group by cno)

6:查询选修了3门以上的课程的学生学号

 select sno

 from sc

 group by sno

   having count(*)>3

:连接查询:

<1>等值与非等值的连接查询

 在连接查询中用来连接两个有的条件称为连接条件或连接谓词,,当连接运算符号为”=”时,称为等值连接,使用如,=,<,>,<=,>=,!=连接时称非等值连接

1:查询每个学生及其选修课程的情况

select student.*,sc.*

from student,sc

where student.sno=sc.sno

<2>自身连接

连接操作在同一个表中进行连接查询

2:查询每一门课的间接先修课(即先修课的先修课)

select first .cno,second.cno

from course first ,course second

where first.cno=second.cno

五:复合条件连接

1:查询选修2号课程且成绩在90分以上的所有学生。

Select student,sname

form student, sc

Where student.sno=sc.sno And

Sc.cno=’2’ and sc.grade>90

六:嵌套查询

1:带有谓词in的子查询

<1>查询与“刘晨”在同一个系学习的学生

select sno,sname,sdept

from student

where sdept in(

 select sdept

 from student

 where sname=”刘晨”)

或:select s1.sname,s1.sdept

from student s1,student s2

where s1.dept=s2.dept and s2.name=”刘晨”

<2>查询选修了课程名为“信息系统”的学生学号和姓名

select sno,sname

from student

where sno in

( select sno

 from sc

 where cno in

     (select cno

        from course

          where cname-“信息系统”)

或:select sno,sname

   from student,sc,course

 where student.sno=sc.sno and

       sc.cno=course.cno and

       course.cname=’信息系统’)

2:带有Any all谓词的子查询

<1>查询其他系中比信息系中某一学生年龄小的学生姓名和年龄

select sname, sage

from student

where sage <any(select sage

       from student

where sdept=’is’

and sdept<>’is’

或用集函数:select sname, sage

from student

where sage<

(select max(sage)

 from student

 where sdept=’is’)

and sdept<>’is’

<2> 查询其他系中比信息系所有学生年龄都小的学生姓名及年龄

select sname, sage

from student

where sage<all

        (select sage

        from student

       where sdept=’is’)

    and sdept<>’is’

3 带有Exitst谓词的子查询

<1>查询所有选修了1号课程的学生姓名

select sname

from student

where exists

        (select *

         from sc

         where sno=student.sno and cno=’1’)

<2>查询没有选修1号课程的学生姓名

 select sname

form student

where not exists

          (select *

            form sc

             where sno=stuedent.sno and cno=’1’)

<2>查询选修所有全部课程的学生姓名

select sname

from student

 where not exists

        (select *

          from course

            where not exists

                  (select *

                     from sc

                       where sno=student.sno

              and cno=course.cno)

<3>查询到少选修了学生95002选修的全部课程的学生号码

select distinct sno

 from sc scx

 where not exists

       ( select *

          from sc scy

           where scy.sno=’95002’ and

              not exists

                  ( select *

                     from sc scz

                      where scz.sno=scx.sno and

                         scz.cno=scy.cno)

 

一个选课模型及SQL语句()

                                                                                           黄邦县

Sid Sname     Birthday

S001       陈小艳    1980-10-01

S002       李中成    1979-06-10

S003       张华       1981-04-05

S004       黄家文    1978-03-12

S005       张文靓    1979-05-24

S006       王小东    1980-05-27

S007       陆江坤    1980-04-10

S008       陈炳秋    1981-04-05

S009       许佳       1980-05-27

S010       杨真       1979-04-05

课程表(Course)

Cid Cname    Score

C01 语文       60

C02 数学       60

C03 物理       60

C04 化学       60

C05 政治       60

选课表(st_co)

Sid Sname     Score

S001       C01 70

S001       C02 65

S001       C03 55

S002       C01 60

S002       C02 74

S003       C01 68

S003       C02 80

S003       C03 74

S004       C01 80

S004       C02 56

S004       C03 66

S004       C04 63

S004       C05 50

S005       C01 67

S006       C01 71

S006       C02 60

S007       C01 58

S007       C02 65

S007       C03 74

S007       C04 85

S007       C05 70

Create table Student (

 Sid             varchar(12) primary key,

 Sname       varchar(20) ,

 Birthday      datetime

)

 

Create table Course (

 Cid             varchar(12) primary key,

 Cname       varchar(20) ,

 Score        int

)

 

Create table st_co (

 Sid      varchar(12),

 Cid     varchar(12) ,

 Score int

 

 Constraint “pk_Id” primary key on (sid, cid)

)

 

Insert into student(sid, sname, birthday)

 Values(s001, ‘陈小艳’, 1980-10-01)

 

 

Insert into course(cid, cname, score)

 Values(c01, ‘语文’, 60)

 

Insert into st_co(sid, cid)

 Values(‘s001’, ‘c01’, 70)

 列出学生张华(学号:s003)所选修的所有课程。

Select s.sid, s.sname, c.cid, c.cname

 From student s, course c, st_co sc

 Where s.sid = ‘s003’ and sc.sid = s.sid and c.cid = sc.cid

 

     列出所有学生及其选修的所有课程。

Select s.sid, s.sname, c.cid, c.cname

 From student s, st_co sc, course c

 Where sc.sid = s.sid and c.cid = sc.cid

 

     列出选修完所有课程的学生。

Select s.sid, s.sname

 From student s

 Where not exists

(select c.cid

 From course c

 Where c.cid not in

    (select sc.cid

         From st_co sc

       Where sc.sid = s.sid

    )

)

      

    列出没有选修完所有课程的学生。

Select s.sid, s.sname

 From student s

 Where exists

(select c.cid

 From cource c

 Where c.cid not in

    (select sc.cid

         From st_co sc

       Where sc.sid = s.sid

    )

)

 

     列出已选修有课程的学生。

Select s.sid, s.sname

 From student s

 Where exists

   (select sc.cid

From st_co sc

Where sc.sid = s.sid

         )

      

     列出没有选修有一门课程的学生。

Select s.sid, s.sname

 From student s

 Where not exists

   (select sc.cid

From st_co sc

Where sc.sid = s.sid

         )

 

     列出选修有3门以上课程的学生。

Select s.sid, s.sname

 From student s

 Where exists

(select sc.sid

 From st_co sc

 Where sc.sid = s.sid

 Group by sc.sid

 Having count(sc.cid) >= 3

              )

      

     列出选修有3门以下课程的学生(不包括没有选修的学生)

Select s.sid, s.sname

 From student s

 Where exists

(select sc.cid

 From st_co sc

 Where sc.sid = s.sid

 Group by sc.cid

 Having count(sc.cid) < 3

              )

注:若包括没有选修的学生。

 

     列出选修课程最多的学生。

Select s.sid, s.sname

From student s

Where s.sid in

(select sid

From

     (select sc.sid, count(sc.cid) as c_count

       From st_co sc

       Group by sc.sid

     ) as st_co_count

   where c_count in

    (select max(c_count)

      From

        (select sc.sid, count(sc.cid) as c_count

          From st_co sc

          Group by sc.sid

        ) as st_co_count

     )

 )

     列出选修课程最少的学生。

Select s.sid, s.sname

From student s

Where s.sid in

(select sid

From

     (select sc.sid, count(sc.cid) as c_count

       From st_co sc

       Group by sc.sid

     ) as st_co_count

   where c_count in

    (select min(c_count)

      From

        (select sc.sid, count(sc.cid) as c_count

          From st_co sc

          Group by sc.sid

        ) as st_co_count

     )

 )

注:不包括没有选修有课程的学生。

     列出选修了所有张华(学号:s003)所选修的课程的学生。

Select s.sid, s.sname

 From student s

 Where not exists

(select cid

 From

    (select c.cid

      From st_co sc

      Where sc.sid = ‘s003’

    ) as s003_co

 Where cid not in

    (select cid

      From st_co sc

      Where sid = s.sid

    )

)

     列出没有选修完所有的张华(学号:s003)所选修的课程的学生。

Select s.sid, s.sname

 From student s

 Where exists

(select cid

 From

    (select c.cid

      From st_co sc

      Where sc.sid = ‘s003’

    ) as s003_co

 Where cid not in

    (select cid

      From st_co sc

      Where sid = s.sid

    )

)

     列出选修的课程比张华(学号:s003)多或相等的学生。

Select s.sid, s.sname

    From student s

    Where exists

       (select sc.sid

         From st_co sc

         Where sc.sid = s.sid

         Group by sc.sid

         Having count(sc.cid) >=

           (select count(sc.cid)

             From st_co sc

             Where sc.sid = 's003'

               Group by sc.sid

           )

       )

     列出选修的课程比张华(学号:s003)少的学生。

Select s.sid, s.sname

    From student s

    Where exists

       (select sc.sid

         From st_co sc

         Where sc.sid = s.sid

         Group by sc.sid

         Having count(sc.cid) <

           (select count(sc.cid)

             From st_co sc

             Where sc.sid = 's003'

               Group by sc.sid

           )

)

       注:不包括没有选修有课程的学生。

 数据库人员面试:SQL Server常用测试题(转载)题目1

  问题描述:

  为管理岗位业务培训信息,建立3个表:

  S (S#,SN,SD,SA) S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄

  C (C#,CN ) C#,CN 分别代表课程编号、课程名称

  SC ( S#,C#,G ) S#,C#,G 分别代表学号、所选修的课程编号、学习成绩

  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 ([S#]))

  5. 查询选修了课程的学员人数

  --实现代码:

  SELECT 学员人数=COUNT(DISTINCT [S#]) FROM SC

  6. 查询选修课程超过5门的学员学号和所属单位

  --实现代码:

  SELECT SN, SD FROM S

  WHERE [S#] IN (

  SELECT [S#] FROM SC

  GROUP BY [S#]

  HAVING COUNT (DISTINCT [C#])>5)

题目2

  问题描述:

  已知关系模式:

  S (SNO,SNAME) 学生关系。SNO 为学号,SNAME 为姓名

  C (CNO,CNAME,CTEACHER) 课程关系。CNO 为课程号,CNAME 为课程名,CTEACHER 为任课教师

  SC(SNO,CNO,SCGRADE) 选课关系。SCGRADE 为成绩

  1. 找出没有选修过“李明”老师讲授课程的所有学生姓名

  --实现代码:

  SELECT SNAME FROM S

  WHERE NOT EXISTS (

  SELECT * FROM SC, C

  WHERE SC.CNO=C.CNO

  AND CNAME='李明'

  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.SNAME

  3. 列出既学过“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, (

  SELECT SC1.SNO

  FROM SC SC1, C C1, SC SC2, C C2

  WHERE SC1.CNO=C1.CNO AND C1.NAME='1'

  AND SC2.CNO=C2.CNO AND C2.NAME='2'

  AND SC1.SCGRADE>SC2.SCGRADE

  )SC WHERE S.SNO=SC.SNO

  5. 列出“1”号课成绩比“2”号课成绩高的所有学生的学号及其“1”号课和“2”号课的成绩

  --实现代码:

  SELECT S.SNO,S.SNAME,SC.[1号课成绩],SC.[2号课成绩]

  FROM S,(

  SELECT SC1.SNO,[1号课成绩]=SC1.SCGRADE,[2号课成绩]=SC2.SCGRADE

  FROM SC SC1,C C1,SC SC2,C C2

  WHERE SC1.CNO=C1.CNO AND C1.NAME='1'

  AND SC2.CNO=C2.CNO AND C2.NAME='2'

  AND SC1.SCGRADE>SC2.SCGRADE

  )SC WHERE S.SNO=SC.SNO