sql 语句

时间:2024-08-04 09:57:36编辑:阿星

数据库常用sql语句有哪些

  数据库常用sql语句   Student(S#,Sname,Sage,Ssex) 学生表   Course(C#,Cname,T#) 课程表   SC(S#,C#,score) 成绩表   Teacher(T#,Tname) 教师表   问题:   1、查询“001”课程比“002”课程成绩高的所有学生的学号;   select a.S# from (select s#,score from SC where C#='001') a,(select s#,score   from SC where C#='002') b   where a.score>b.score and a.s#=b.s#;   2、查询平均成绩大于60分的同学的学号和平均成绩;   select S#,avg(score)   from sc   group by S# having avg(score) >60;   3、查询所有同学的学号、姓名、选课数、总成绩;   select Student.S#,Student.Sname,count(SC.C#),sum(score)   from Student left Outer join SC on Student.S#=SC.S#   group by Student.S#,Sname   4、查询姓“李”的老师的个数;   select count(distinct(Tname))   from Teacher   where Tname like '李%';   5、查询没学过“叶平”老师课的同学的学号、姓名;   select Student.S#,Student.Sname   from Student   where S# not in (select distinct( SC.S#) from SC,Course,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='叶平');   6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;   select Student.S#,Student.Sname from Student,SC where Student.S#=SC.S# and SC.C#='001'and exists( Select * from SC as SC_2 where SC_2.S#=SC.S# and SC_2.C#='002');   7、查询学过“叶平”老师所教的所有课的同学的学号、姓名;   select S#,Sname   from Student   where S# in (select S# from SC ,Course ,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='叶平' group by S# having count(SC.C#)=(select count(C#) from Course,Teacher where Teacher.T#=Course.T# and Tname='叶平'));   8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;   Select S#,Sname from (select Student.S#,Student.Sname,score ,(select score from SC SC_2 where SC_2.S#=Student.S# and SC_2.C#='002') score2   from Student,SC where Student.S#=SC.S# and C#='001') S_2 where score2<score;   9、查询所有课程成绩小于60分的同学的学号、姓名;   select S#,Sname   from Student   where S# not in (select Student.S# from Student,SC where S.S#=SC.S# and score>60);   10、查询没有学全所有课的同学的学号、姓名;   select Student.S#,Student.Sname   from Student,SC   where Student.S#=SC.S# group by Student.S#,Student.Sname having count(C#) <(select count(C#) from Course);   11、查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;   select S#,Sname from Student,SC where Student.S#=SC.S# and C# in select C# from SC where S#='1001';   12、查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;   select distinct SC.S#,Sname   from Student,SC   where Student.S#=SC.S# and C# in (select C# from SC where S#='001');   13、把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;   SC set score=(select avg(SC_2.score)   from SC SC_2   where SC_2.C#=SC.C# ) from Course,Teacher where Course.C#=SC.C# and Course.T#=Teacher.T# and Teacher.Tname='叶平');   14、查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名;   select S# from SC where C# in (select C# from SC where S#='1002')   group by S# having count(*)=(select count(*) from SC where S#='1002');   15、删除学习“叶平”老师课的SC表记录;   Delect SC   from course ,Teacher   where Course.C#=SC.C# and Course.T#= Teacher.T# and Tname='叶平';   16、向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003”课程的同学学号、2、   号课的平均成绩;   Insert SC select S#,'002',(Select avg(score)   from SC where C#='002') from Student where S# not in (Select S# from SC where C#='002');   17、按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分   SELECT S# as 学生ID   ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='004') AS 数据库   ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='001') AS 企业管理   ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='006') AS 英语   ,COUNT(*) AS 有效课程数, AVG(t.score) AS 平均成绩   FROM SC AS t   GROUP BY S#   ORDER BY avg(t.score)   18、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分   SELECT L.C# As 课程ID,L.score AS 最高分,R.score AS 最低分   FROM SC L ,SC AS R   WHERE L.C# = R.C# and   L.score = (SELECT MAX(IL.score)   FROM SC AS IL,Student AS IM   WHERE L.C# = IL.C# and IM.S#=IL.S#   GROUP BY IL.C#)   AND   R.Score = (SELECT MIN(IR.score)   FROM SC AS IR   WHERE R.C# = IR.C#   GROUP BY IR.C#   );   19、按各科平均成绩从低到高和及格率的百分数从高到低顺序   SELECT t.C# AS 课程号,max(course.Cname)AS 课程名,isnull(AVG(score),0) AS 平均成绩   ,100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) AS 及格百分数   FROM SC T,Course   where t.C#=course.C#   GROUP BY t.C#   ORDER BY 100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) DESC   20、查询如下课程平均成绩和及格率的百分数(用"1行"显示): 企业管理(001),马克思(002),OO&UML (003),数据库(004)   SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS 企业管理平均分   ,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '001' THEN 1 ELSE 0 END) AS 企业管理及格百分数   ,SUM(CASE WHEN C# = '002' THEN score ELSE 0 END)/SUM(CASE C# WHEN '002' THEN 1 ELSE 0 END) AS 马克思平均分   ,100 * SUM(CASE WHEN C# = '002' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '002' THEN 1 ELSE 0 END) AS 马克思及格百分数   ,SUM(CASE WHEN C# = '003' THEN score ELSE 0 END)/SUM(CASE C# WHEN '003' THEN 1 ELSE 0 END) AS UML平均分   ,100 * SUM(CASE WHEN C# = '003' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '003' THEN 1 ELSE 0 END) AS UML及格百分数   ,SUM(CASE WHEN C# = '004' THEN score ELSE 0 END)/SUM(CASE C# WHEN '004' THEN 1 ELSE 0 END) AS 数据库平均分   ,100 * SUM(CASE WHEN C# = '004' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '004' THEN 1 ELSE 0 END) AS 数据库及格百分数   FROM SC   21、查询不同老师所教不同课程平均分从高到低显示   SELECT max(Z.T#) AS 教师ID,MAX(Z.Tname) AS 教师姓名,C.C# AS 课程ID,MAX(C.Cname) AS 课程名称,AVG(Score) AS 平均成绩   FROM SC AS T,Course AS C ,Teacher AS Z   where T.C#=C.C# and C.T#=Z.T#   GROUP BY C.C#   ORDER BY AVG(Score) DESC   22、查询如下课程成绩第 3 名到第 6 名的学生成绩单:企业管理(001),马克思(002),UML (003),数据库(004)   [学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩   SELECT DISTINCT top 3   SC.S# As 学生学号,   Student.Sname AS 学生姓名 ,   T1.score AS 企业管理,   T2.score AS 马克思,   T3.score AS UML,   T4.score AS 数据库,   ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) as 总分   FROM Student,SC LEFT JOIN SC AS T1   ON SC.S# = T1.S# AND T1.C# = '001'   LEFT JOIN SC AS T2   ON SC.S# = T2.S# AND T2.C# = '002'   LEFT JOIN SC AS T3   ON SC.S# = T3.S# AND T3.C# = '003'   LEFT JOIN SC AS T4   ON SC.S# = T4.S# AND T4.C# = '004'   WHERE student.S#=SC.S# and   ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)   NOT IN   (SELECT   DISTINCT   TOP 15 WITH TIES   ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)   FROM sc   LEFT JOIN sc AS T1   ON sc.S# = T1.S# AND T1.C# = 'k1'   LEFT JOIN sc AS T2   ON sc.S# = T2.S# AND T2.C# = 'k2'   LEFT JOIN sc AS T3   ON sc.S# = T3.S# AND T3.C# = 'k3'   LEFT JOIN sc AS T4   ON sc.S# = T4.S# AND T4.C# = 'k4'   ORDER BY ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) DESC);   23、统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[<60]   SELECT SC.C# as 课程ID, Cname as 课程名称   ,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85]   ,SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70]   ,SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60]   ,SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]   FROM SC,Course   where SC.C#=Course.C#   GROUP BY SC.C#,Cname;   24、查询学生平均成绩及其名次   SELECT 1+(SELECT COUNT( distinct 平均成绩)   FROM (SELECT S#,AVG(score) AS 平均成绩   FROM SC   GROUP BY S#   ) AS T1   WHERE 平均成绩 > T2.平均成绩) as 名次,   S# as 学生学号,平均成绩   FROM (SELECT S#,AVG(score) 平均成绩   FROM SC   GROUP BY S#   ) AS T2   ORDER BY 平均成绩 desc;   25、查询各科成绩前三名的记录:(不考虑成绩并列情况)   SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数   FROM SC t1   WHERE score IN (SELECT TOP 3 score   FROM SC   WHERE t1.C#= C#   ORDER BY score DESC   )   ORDER BY t1.C#;   26、查询每门课程被选修的学生数   select c#,count(S#) from sc group by C#;   27、查询出只选修了一门课程的全部学生的学号和姓名   select SC.S#,Student.Sname,count(C#) AS 选课数   from SC ,Student   where SC.S#=Student.S# group by SC.S# ,Student.Sname having count(C#)=1;   28、查询男生、女生人数   Select count(Ssex) as 男生人数 from Student group by Ssex having Ssex='男';   Select count(Ssex) as 女生人数 from Student group by Ssex having Ssex='女';   29、查询姓“张”的学生名单   SELECT Sname FROM Student WHERE Sname like '张%';   30、查询同名同性学生名单,并统计同名人数   select Sname,count(*) from Student group by Sname having count(*)>1;;   31、1981年出生的学生名单(注:Student表中Sage列的类型是datetime)   select Sname, CONVERT(char (11),DATEPART(year,Sage)) as age   from student   where CONVERT(11),DATEPART(year,Sage))='1981';   32、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列   Select C#,Avg(score) from SC group by C# order by Avg(score),C# DESC ;   33、查询平均成绩大于85的所有学生的学号、姓名和平均成绩   select Sname,SC.S# ,avg(score)   from Student,SC   where Student.S#=SC.S# group by SC.S#,Sname having avg(score)>85;   34、查询课程名称为“数据库”,且分数低于60的学生姓名和分数   Select Sname,isnull(score,0)   from Student,SC,Course   where SC.S#=Student.S# and SC.C#=Course.C# and Course.Cname='数据库'and score<60;   35、查询所有学生的选课情况;   SELECT SC.S#,SC.C#,Sname,Cname   FROM SC,Student,Course   where SC.S#=Student.S# and SC.C#=Course.C# ;   36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数;   SELECT distinct student.S#,student.Sname,SC.C#,SC.score   FROM student,Sc   WHERE SC.score>=70 AND SC.S#=student.S#;   37、查询不及格的课程,并按课程号从大到小排列   select c# from sc where scor e<60 order by C# ;   38、查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;   select SC.S#,Student.Sname from SC,Student where SC.S#=Student.S# and Score>80 and C#='003';   39、求选了课程的学生人数   select count(*) from sc;   40、查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩   select Student.Sname,score   from Student,SC,Course C,Teacher   where Student.S#=SC.S# and SC.C#=C.C# and C.T#=Teacher.T# and Teacher.Tname='叶平' and SC.score=(select max(score)from SC where C#=C.C# );   41、查询各个课程及相应的选修人数   select count(*) from sc group by C#;   42、查询不同课程成绩相同的学生的学号、课程号、学生成绩   select distinct A.S#,B.score from SC A ,SC B where A.Score=B.Score and A.C# B.C# ;   43、查询每门功成绩最好的前两名   SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数   FROM SC t1   WHERE score IN (SELECT TOP 2 score   FROM SC   WHERE t1.C#= C#   ORDER BY score DESC   )   ORDER BY t1.C#;   44、统计每门课程的学生选修人数(超过10人的课程才统计)。要求输出课程号和选修人数,查询结果按人数降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列   select C# as 课程号,count(*) as 人数   from sc   group by C#   order by count(*) desc,c#   45、检索至少选修两门课程的学生学号   select S#   from sc   group by s#   having count(*) > = 2   46、查询全部学生都选修的课程的'课程号和课程名   select C#,Cname   from Course   where C# in (select c# from sc group by c#)   47、查询没学过“叶平”老师讲授的任一门课程的学生姓名   select Sname from Student where S# not in (select S# from Course,Teacher,SC where Course.T#=Teacher.T# and SC.C#=course.C# and Tname='叶平');   48、查询两门以上不及格课程的同学的学号及其平均成绩   select S#,avg(isnull(score,0)) from SC where S# in (select S# from SC where score2)group by S#;   49、检索“004”课程分数小于60,按分数降序排列的同学学号   select S# from SC where C#='004'and score<60 order by score desc;   50、删除“002”同学的“001”课程的成绩   from Sc where S#='001'and C#='001';   一、SQL语言简介   1、SQL语言简介   SQL是结构化查询语言(Structured Query Language),是用于访问和处理数据库的标准的计算机语言。   SQL语言的功能如下:   A、SQL面向数据库执行查询   B、SQL可从数据库取回数据   C、SQL可在数据库中插入新的记录   D、SQL可更新数据库中的数据   E、SQL可从数据库删除记录   F、SQL可创建新数据库   G、SQL可在数据库中创建新表   H、SQL可在数据库中创建存储过程   I、SQL可在数据库中创建视图   J、SQL可以设置表、存储过程和视图的权限   SQL是一门ANSI的标准计算机语言,用来访问和操作数据库系统。SQL语句用于取回和更新数据库中的数据。SQL可与数据库程序协同工作,比如MS Access、DB2、Informix、MS SQL Server、Oracle、MySQL、Sybase以及其他数据库系统。   每一种数据库有自己版本的SQL语言,但是为了与ANSI标准相兼容,SQL必须以相似的方式共同地来支持一些主要的关键词(比如 SELECT、UPDATE、DELETE、INSERT、WHERE等等)。   除了SQL标准之外,大部分SQL数据库程序都拥有自己的私有扩展。   2、SQL语言分类   SQL语言分为数据定义语言、数据控制语言、数据操作语言、数据查询语言,分别实现对数据库数据操作。   二、SQL语言基础   1、数据定义语言(DDL)   DDL:Data Definition Language   用于定义和管理数据对象,包括数据库、数据表、函数、视图、索引、触发器等。例如:CREATE、DROP、ALTER等语句。   create table student   (   sid INT,   sname var20)   );   alter table student add age int default 20;    student;   drop database student;   2、数据控制语言(DCL)   DCL:Data Control Language   用来管理数据库的语言,包含授权用户访问、拒绝用户访问、撤销授予的权限。例如:GRANT、DENY、REVOKE、COMMIT、ROLLBACK等语句。   创建用户   create user ‘wang’@‘localhost’ identified by ‘a1!’;   权限设置   grant select on db.student to ‘wang’@‘localhost’;   撤销权限   revoke select on db.student from ‘wang’@‘localhost’;   3、数据操作语言(DML)   DML:Data Manipulation Language   用于操作数据库对象中所包含的数据,增、删、改。例如:INSERT、DELETE、UPDATE语句。   4、数据查询语言(DQL)   DQL:Data Query Language   用于查询数据库对象中所包含的数据,能够进行单表查询、连接查询、嵌套查询,以及集合查询等各种复杂程度不同的数据库查询,并将数据返回到客户机中显示。例如:SELECT语句。   三、常量和变量   1、常量   A、字符常量   字符串常量使用单引号或双引号,数值常量不用加引号。   如果字符串常量中需要换行、有单引号、双引号 % _   前面需要加转义字符    换行   ’ 一个单引号   ” 一个双引号    一个 如果没有转义字符 就认为是一个转义字符   % 一个% 如果没有转义字符就认为这是一个通配符   _ 一个_ 如果没有转移字符 就认为是一个通配符   select ‘hanli’gang001’   select ‘han ligang001’   select ‘han ligang001’   select “han"ligang001”   select “韩立刚001”   B、数值常量   数值常量不用添加引号,   select 100+100+200   C、布尔常量   布尔型常量取值 true 和 false   在SQL中使用1和0表示   select true,false   在表达式中   select 100>200   select 100<200   2、变量   用户自定义变量使用@开始,使用set给变量赋值。   set @name=‘孙悟空’;   select @name;   select * from student;    into student values (6,‘孙悟空’,20);    into student values (8,@name,20);   set @sid=9,@nid=10    into student values (@sid,@name,20);   select @sid+@nid;   set @sid=@sid+1;   select @sid;   set @sname3=(select sname from student where sid=9);   select @sname3;   3、系统变量   系统变量分为全局系统变量和会话系统变量。   全局系统变量:针对所有默认设置   会话系统变量:针对当前用户生效,用户登录MySQL会使用全局系统变量,如果会话中更改了变量值,使用更改后的值,不过只针对当前用户生效。   show variables 显示会话系统变量   show global variables 显示全局系统变量   show session variables 显示会话系统变量   show global variables like ‘sql_select_limit’;使用通配符显示匹配的变量设置   show session variables like ‘sql_select_limit’;系统变量使用@@标识   select @@global.sql_select_limit 查看某个全局系统变量设置   select @@session.sql_select_limit 查看某个会话系统变量设置   set @@session.sql_select_limit=2 设置会话系统变量   全局系统变量需要在/etc/my.cnf配置文件中修改。

数据库常用sql语句有哪些

数据库常用sql语句有哪些   SQL语句有哪些?SQL语句无论是种类还是数量都是繁多的,很多语句也是经常要用到的,下文我为大家分享的就是SQL的常用语句,仅供参考!   50个常用的sql语句   Student(S#,Sname,Sage,Ssex) 学生表   Course(C#,Cname,T#) 课程表   SC(S#,C#,score) 成绩表   Teacher(T#,Tname) 教师表   问题:   1、查询“001”课程比“002”课程成绩高的所有学生的学号;   select a.S# from (select s#,score from SC where C#='001') a,(select s#,score   from SC where C#='002') b   where a.score>b.score and a.s#=b.s#;   2、查询平均成绩大于60分的同学的学号和平均成绩;   select S#,avg(score)   from sc   group by S# having avg(score) >60;   3、查询所有同学的学号、姓名、选课数、总成绩;   select Student.S#,Student.Sname,count(SC.C#),sum(score)   from Student left Outer join SC on Student.S#=SC.S#   group by Student.S#,Sname   4、查询姓“李”的老师的个数;   select count(distinct(Tname))   from Teacher   where Tname like '李%';   5、查询没学过“叶平”老师课的同学的学号、姓名;   select Student.S#,Student.Sname   from Student   where S# not in (select distinct( SC.S#) from SC,Course,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='叶平');   6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名;   select Student.S#,Student.Sname from Student,SC where Student.S#=SC.S# and SC.C#='001'and exists( Select * from SC as SC_2 where SC_2.S#=SC.S# and SC_2.C#='002');   7、查询学过“叶平”老师所教的所有课的同学的学号、姓名;   select S#,Sname   from Student   where S# in (select S# from SC ,Course ,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='叶平' group by S# having count(SC.C#)=(select count(C#) from Course,Teacher where Teacher.T#=Course.T# and Tname='叶平'));   8、查询课程编号“002”的成绩比课程编号“001”课程低的所有同学的学号、姓名;   Select S#,Sname from (select Student.S#,Student.Sname,score ,(select score from SC SC_2 where SC_2.S#=Student.S# and SC_2.C#='002') score2   from Student,SC where Student.S#=SC.S# and C#='001') S_2 where score2 <score;   9、查询所有课程成绩小于60分的同学的学号、姓名;   select S#,Sname   from Student   where S# not in (select Student.S# from Student,SC where S.S#=SC.S# and score>60);   10、查询没有学全所有课的同学的学号、姓名;   select Student.S#,Student.Sname   from Student,SC   where Student.S#=SC.S# group by Student.S#,Student.Sname having count(C#) <(select count(C#) from Course);   11、查询至少有一门课与学号为“1001”的同学所学相同的同学的学号和姓名;   select S#,Sname from Student,SC where Student.S#=SC.S# and C# in select C# from SC where S#='1001';   12、查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;   select distinct SC.S#,Sname   from Student,SC   where Student.S#=SC.S# and C# in (select C# from SC where S#='001');   13、把“SC”表中“叶平”老师教的课的成绩都更改为此课程的平均成绩;   update SC set score=(select avg(SC_2.score)   from SC SC_2   where SC_2.C#=SC.C# ) from Course,Teacher where Course.C#=SC.C# and Course.T#=Teacher.T# and Teacher.Tname='叶平');   14、查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名;   select S# from SC where C# in (select C# from SC where S#='1002')   group by S# having count(*)=(select count(*) from SC where S#='1002');   15、删除学习“叶平”老师课的SC表记录;   Delect SC   from course ,Teacher   where Course.C#=SC.C# and Course.T#= Teacher.T# and Tname='叶平';   16、向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003”课程的同学学号、2、   号课的平均成绩;   Insert SC select S#,'002',(Select avg(score)   from SC where C#='002') from Student where S# not in (Select S# from SC where C#='002');   17、按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示: 学生ID,,数据库,企业管理,英语,有效课程数,有效平均分   SELECT S# as 学生ID   ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='004') AS 数据库   ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='001') AS 企业管理   ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='006') AS 英语   ,COUNT(*) AS 有效课程数, AVG(t.score) AS 平均成绩   FROM SC AS t   GROUP BY S#   ORDER BY avg(t.score)   18、查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分   SELECT L.C# As 课程ID,L.score AS 最高分,R.score AS 最低分   FROM SC L ,SC AS R   WHERE L.C# = R.C# and   L.score = (SELECT MAX(IL.score)   FROM SC AS IL,Student AS IM   WHERE L.C# = IL.C# and IM.S#=IL.S#   GROUP BY IL.C#)   AND   R.Score = (SELECT MIN(IR.score)   FROM SC AS IR   WHERE R.C# = IR.C#   GROUP BY IR.C#   );   19、按各科平均成绩从低到高和及格率的百分数从高到低顺序   SELECT t.C# AS 课程号,max(course.Cname)AS 课程名,isnull(AVG(score),0) AS 平均成绩   ,100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) AS 及格百分数   FROM SC T,Course   where t.C#=course.C#   GROUP BY t.C#   ORDER BY 100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) DESC   20、查询如下课程平均成绩和及格率的百分数(用"1行"显示): 企业管理(001),马克思(002),OO&UML (003),数据库(004)   SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS 企业管理平均分   ,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '001' THEN 1 ELSE 0 END) AS 企业管理及格百分数   ,SUM(CASE WHEN C# = '002' THEN score ELSE 0 END)/SUM(CASE C# WHEN '002' THEN 1 ELSE 0 END) AS 马克思平均分   ,100 * SUM(CASE WHEN C# = '002' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '002' THEN 1 ELSE 0 END) AS 马克思及格百分数   ,SUM(CASE WHEN C# = '003' THEN score ELSE 0 END)/SUM(CASE C# WHEN '003' THEN 1 ELSE 0 END) AS UML平均分   ,100 * SUM(CASE WHEN C# = '003' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '003' THEN 1 ELSE 0 END) AS UML及格百分数   ,SUM(CASE WHEN C# = '004' THEN score ELSE 0 END)/SUM(CASE C# WHEN '004' THEN 1 ELSE 0 END) AS 数据库平均分   ,100 * SUM(CASE WHEN C# = '004' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '004' THEN 1 ELSE 0 END) AS 数据库及格百分数   FROM SC   21、查询不同老师所教不同课程平均分从高到低显示   SELECT max(Z.T#) AS 教师ID,MAX(Z.Tname) AS 教师姓名,C.C# AS 课程ID,MAX(C.Cname) AS 课程名称,AVG(Score) AS 平均成绩   FROM SC AS T,Course AS C ,Teacher AS Z   where T.C#=C.C# and C.T#=Z.T#   GROUP BY C.C#   ORDER BY AVG(Score) DESC   22、查询如下课程成绩第 3 名到第 6 名的学生成绩单:企业管理(001),马克思(002),UML (003),数据库(004)   [学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩   SELECT DISTINCT top 3   SC.S# As 学生学号,   Student.Sname AS 学生姓名 ,   T1.score AS 企业管理,   T2.score AS 马克思,   T3.score AS UML,   T4.score AS 数据库,   ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) as 总分   FROM Student,SC LEFT JOIN SC AS T1   ON SC.S# = T1.S# AND T1.C# = '001'   LEFT JOIN SC AS T2   ON SC.S# = T2.S# AND T2.C# = '002'   LEFT JOIN SC AS T3   ON SC.S# = T3.S# AND T3.C# = '003'   LEFT JOIN SC AS T4   ON SC.S# = T4.S# AND T4.C# = '004'   WHERE student.S#=SC.S# and   ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)   NOT IN   (SELECT   DISTINCT   TOP 15 WITH TIES   ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)   FROM sc   LEFT JOIN sc AS T1   ON sc.S# = T1.S# AND T1.C# = 'k1'   LEFT JOIN sc AS T2   ON sc.S# = T2.S# AND T2.C# = 'k2'   LEFT JOIN sc AS T3   ON sc.S# = T3.S# AND T3.C# = 'k3'   LEFT JOIN sc AS T4   ON sc.S# = T4.S# AND T4.C# = 'k4'   ORDER BY ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) DESC);   23、统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[ <60]   SELECT SC.C# as 课程ID, Cname as 课程名称   ,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85]   ,SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70]   ,SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60]   ,SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]   FROM SC,Course   where SC.C#=Course.C#   GROUP BY SC.C#,Cname;   24、查询学生平均成绩及其名次   SELECT 1+(SELECT COUNT( distinct 平均成绩)   FROM (SELECT S#,AVG(score) AS 平均成绩   FROM SC   GROUP BY S#   ) AS T1   WHERE 平均成绩 > T2.平均成绩) as 名次,   S# as 学生学号,平均成绩   FROM (SELECT S#,AVG(score) 平均成绩   FROM SC   GROUP BY S#   ) AS T2   ORDER BY 平均成绩 desc;   25、查询各科成绩前三名的记录:(不考虑成绩并列情况)   SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数   FROM SC t1   WHERE score IN (SELECT TOP 3 score   FROM SC   WHERE t1.C#= C#   ORDER BY score DESC   )   ORDER BY t1.C#;   26、查询每门课程被选修的学生数   select c#,count(S#) from sc group by C#;   27、查询出只选修了一门课程的全部学生的学号和姓名   select SC.S#,Student.Sname,count(C#) AS 选课数   from SC ,Student   where SC.S#=Student.S# group by SC.S# ,Student.Sname having count(C#)=1;   28、查询男生、女生人数   Select count(Ssex) as 男生人数 from Student group by Ssex having Ssex='男';   Select count(Ssex) as 女生人数 from Student group by Ssex having Ssex='女';   29、查询姓“张”的.学生名单   SELECT Sname FROM Student WHERE Sname like '张%';   30、查询同名同性学生名单,并统计同名人数   select Sname,count(*) from Student group by Sname having count(*)>1;;   31、1981年出生的学生名单(注:Student表中Sage列的类型是datetime)   select Sname, CONVERT(char (11),DATEPART(year,Sage)) as age   from student   where CONVERT(char(11),DATEPART(year,Sage))='1981';   32、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列   Select C#,Avg(score) from SC group by C# order by Avg(score),C# DESC ;   33、查询平均成绩大于85的所有学生的学号、姓名和平均成绩   select Sname,SC.S# ,avg(score)   from Student,SC   where Student.S#=SC.S# group by SC.S#,Sname having avg(score)>85;   34、查询课程名称为“数据库”,且分数低于60的学生姓名和分数   Select Sname,isnull(score,0)   from Student,SC,Course   where SC.S#=Student.S# and SC.C#=Course.C# and Course.Cname='数据库'and score <60;   35、查询所有学生的选课情况;   SELECT SC.S#,SC.C#,Sname,Cname   FROM SC,Student,Course   where SC.S#=Student.S# and SC.C#=Course.C# ;   36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数;   SELECT distinct student.S#,student.Sname,SC.C#,SC.score   FROM student,Sc   WHERE SC.score>=70 AND SC.S#=student.S#;   37、查询不及格的课程,并按课程号从大到小排列   select c# from sc where scor e <60 order by C# ;   38、查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;   select SC.S#,Student.Sname from SC,Student where SC.S#=Student.S# and Score>80 and C#='003';   39、求选了课程的学生人数   select count(*) from sc;   40、查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩   select Student.Sname,score   from Student,SC,Course C,Teacher   where Student.S#=SC.S# and SC.C#=C.C# and C.T#=Teacher.T# and Teacher.Tname='叶平' and SC.score=(select max(score)from SC where C#=C.C# );   41、查询各个课程及相应的选修人数   select count(*) from sc group by C#;   42、查询不同课程成绩相同的学生的学号、课程号、学生成绩   select distinct A.S#,B.score from SC A ,SC B where A.Score=B.Score and A.C# B.C# ;   43、查询每门功成绩最好的前两名   SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数   FROM SC t1   WHERE score IN (SELECT TOP 2 score   FROM SC   WHERE t1.C#= C#   ORDER BY score DESC   )   ORDER BY t1.C#;   44、统计每门课程的学生选修人数(超过10人的课程才统计)。要求输出课程号和选修人数,查询结果按人数降序排列,查询结果按人数降序排列,若人数相同,按课程号升序排列   select C# as 课程号,count(*) as 人数   from sc   group by C#   order by count(*) desc,c#   45、检索至少选修两门课程的学生学号   select S#   from sc   group by s#   having count(*) > = 2   46、查询全部学生都选修的课程的课程号和课程名   select C#,Cname   from Course   where C# in (select c# from sc group by c#)   47、查询没学过“叶平”老师讲授的任一门课程的学生姓名   select Sname from Student where S# not in (select S# from Course,Teacher,SC where Course.T#=Teacher.T# and SC.C#=course.C# and Tname='叶平');   48、查询两门以上不及格课程的同学的学号及其平均成绩   select S#,avg(isnull(score,0)) from SC where S# in (select S# from SC where score 2)group by S#;   49、检索“004”课程分数小于60,按分数降序排列的同学学号   select S# from SC where C#='004'and score <60 order by score desc;   50、删除“002”同学的“001”课程的成绩   delete from Sc where S#='001'and C#='001'; ;


SQL语句语法大全

  我整理的一些比较常用的SQL语句语法 需要的朋友可以过来参考下   一 数据控制语句 (DML) 部分    INSERT (往数据表里插入记录的语句)   INSERT INTO 表名(字段名 字段名 ……) VALUES ( 值 值 ……);   INSERT INTO 表名(字段名 字段名 ……) SELECT 字段名 字段名 …… FROM 另外的表名;   字符串类型的字段值必须用单引号括起来 例如: GOOD DAY   如果字段值里包含单引号 需要进行字符串转换 我们把它替换成两个单引号   字符串类型的字段值超过定义的长度会出错 最好在插入前进行长度校验   日期字段的字段值可以用当前数据库的系统时间SYSDATE 精确到秒   或者用字符串转换成日期型函数TO_DATE(‘ YYYY MM DD )   TO_DATE()还有很多种日期格式 可以参看ORACLE DOC   年 月 日 小时:分钟:秒 的格式YYYY MM DD HH :MI:SS   INSERT时最大可操作的字符串长度小于等于 个单字节 如果要插入更长的字符串 请考虑字段用CLOB类型   方法借用ORACLE里自带的DBMS_LOB程序包   INSERT时如果要用到从 开始自动增长的序列号 应该先建立一个序列号   CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY START WITH   MAXVALUE CYCLE NOCACHE;   其中最大的值按字段的长度来定 如果定义的自动增长的序列号 NUMBER( ) 最大值为   INSERT 语句插入这个字段值为: 序列号的名称 NEXTVAL    DELETE (删除数据表里记录的语句)   DELETE FROM表名 WHERE 条件;   注意 删除记录并不能释放ORACLE里被占用的数据块表空间 它只把那些被删除的数据块标成unused   如果确实要删除一个大表里的全部记录 可以用 TRUNCATE 命令 它可以释放占用的数据块表空间   TRUNCATE TABLE 表名;   此操作不可回退    UPDATE (修改数据表里记录的语句)   UPDATE表名 SET 字段名 =值 字段名 =值 …… WHERE 条件;   如果修改的值N没有赋值或定义时 将把原来的记录内容清为NULL 最好在修改前进行非空校验;   值N超过定义的长度会出错 最好在插入前进行长度校验   注意事项:   A 以上SQL语句对表都加上了行级锁   确认完成后 必须加上事物处理结束的命令 MIT 才能正式生效   否则改变不一定写入数据库里   如果想撤回这些操作 可以用命令 ROLLBACK 复原   B 在运行INSERT DELETE 和 UPDATE 语句前最好估算一下可能操作的记录范围   应该把它限定在较小 (一万条记录) 范围内 否则ORACLE处理这个事物用到很大的回退段   程序响应慢甚至失去响应 如果记录数上十万以上这些操作 可以把这些SQL语句分段分次完成   其间加上MIT 确认事物处理   二 数据定义 (DDL) 部分    CREATE (创建表 索引 视图 同义词 过程 函数 数据库链接等)   ORACLE常用的字段类型有   CHAR 固定长度的字符串   VARCHAR 可变长度的字符串   NUMBER(M N) 数字型M是位数总长度 N是小数的长度   DATE 日期类型   创建表时要把较小的不为空的字段放在前面 可能为空的字段放在后面   创建表时可以用中文的字段名 但最好还是用英文的字段名   创建表时可以给字段加上默认值 例如 DEFAULT SYSDATE   这样每次插入和修改时 不用程序操作这个字段都能得到动作的时间   创建表时可以给字段加上约束条件   例如 不允许重复 UNIQUE 关键字 PRIMARY KEY    ALTER (改变表 索引 视图等)   改变表的名称   ALTER TABLE 表名 TO 表名 ;   在表的后面增加一个字段   ALTER TABLE表名 ADD 字段名 字段名描述;   修改表里字段的定义描述   ALTER TABLE表名 MODIFY字段名 字段名描述;   给表里的字段加上约束条件   ALTER TABLE 表名 ADD CONSTRAINT 约束名 PRIMARY KEY (字段名);   ALTER TABLE 表名 ADD CONSTRAINT 约束名 UNIQUE (字段名);   把表放在或取出数据库的内存区   ALTER TABLE 表名 CACHE;   ALTER TABLE 表名 NOCACHE;    DROP (删除表 索引 视图 同义词 过程 函数 数据库链接等)   删除表和它所有的约束条件   DROP TABLE 表名 CASCADE CONSTRAINTS;    TRUNCATE (清空表里的所有记录 保留表的结构)   TRUNCATE 表名;   三 查询语句 (SELECT) 部分   SELECT字段名 字段名 …… FROM 表名 [表名 ……] WHERE 条件;   字段名可以带入函数   例如: COUNT(*) MIN(字段名) MAX(字段名) AVG(字段名) DISTINCT(字段名)   TO_CHAR(DATE字段名 YYYY MM DD HH :MI:SS )   NVL(EXPR EXPR )函数   解释:   IF EXPR =NULL   RETURN EXPR   ELSE   RETURN EXPR   DECODE(AA﹐V ﹐R ﹐V ﹐R )函数   解释:   IF AA=V THEN RETURN R   IF AA=V THEN RETURN R    …   ELSE   RETURN NULL   LPAD(char n char )函数   解释:   字符char 按制定的位数n显示 不足的位数用char 字符串替换左边的空位   字段名之间可以进行算术运算   例如: (字段名 *字段名 )/   查询语句可以嵌套   例如: SELECT …… FROM   (SELECT …… FROM表名 [表名 ……] WHERE 条件) WHERE 条件 ;   两个查询语句的结果可以做集合操作   例如: 并集UNION(去掉重复记录) 并集UNION ALL(不去掉重复记录) 差集MINUS 交集INTERSECT   分组查询   SELECT字段名 字段名 …… FROM 表名 [表名 ……] GROUP BY字段名   [HAVING 条件] ;   两个以上表之间的连接查询   SELECT字段名 字段名 …… FROM 表名 [表名 ……] WHERE   表名 字段名 = 表名 字段名 [ AND ……] ;   SELECT字段名 字段名 …… FROM 表名 [表名 ……] WHERE   表名 字段名 = 表名 字段名(+) [ AND ……] ;   有(+)号的字段位置自动补空值   查询结果集的排序操作 默认的排序是升序ASC 降序是DESC   SELECT字段名 字段名 …… FROM 表名 [表名 ……]   ORDER BY字段名 字段名 DESC;   字符串模糊比较的方法   INSTR(字段名 ‘字符串 )>   字段名 LIKE ‘字符串% [‘%字符串% ]   每个表都有一个隐含的字段ROWID 它标记着记录的唯一性   四 ORACLE里常用的数据对象 (SCHEMA)    索引 (INDEX)   CREATE INDEX 索引名ON 表名 ( 字段 [字段 ……] );   ALTER INDEX 索引名 REBUILD;   一个表的索引最好不要超过三个 (特殊的大表除外) 最好用单字段索引 结合SQL语句的分析执行情况   也可以建立多字段的组合索引和基于函数的索引   ORACLE 字符串可以索引的最大长度为 单字节   ORACLE 字符串可以索引的最大长度为 单字节   ORACLE DOC上说字符串最大可以建索引的长度约是:数据块的大小(db_block_size)* %    视图 (VIEW)   CREATE VIEW 视图名AS SELECT … FROM … ;   ALTER VIEW视图名 PILE;   视图仅是一个SQL查询语句 它可以把表之间复杂的关系简洁化    同义词 (SYNONMY)   CREATE SYNONYM同义词名FOR 表名;   CREATE SYNONYM同义词名FOR 表名@数据库链接名;    数据库链接 (DATABASE LINK)   CREATE DATABASE LINK数据库链接名CONNECT TO 用户名 IDENTIFIED BY 密码 USING ‘数据库连接字符串 ;   数据库连接字符串可以用NET EASY CONFIG或者直接修改TNSNAMES ORA里定义   数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样   数据库全局名称可以用以下命令查出   SELECT * FROM GLOBAL_NAME;   查询远端数据库里的表   SELECT …… FROM 表名@数据库链接名;   五 权限管理 (DCL) 语句    GRANT 赋于权限   常用的系统权限集合有以下三个:   CONNECT(基本的连接) RESOURCE(程序开发) DBA(数据库管理)   常用的数据对象权限有以下五个:   ALL ON 数据对象名 SELECT ON 数据对象名 UPDATE ON 数据对象名   DELETE ON 数据对象名 INSERT ON 数据对象名 ALTER ON 数据对象名   GRANT CONNECT RESOURCE TO 用户名;   GRANT SELECT ON 表名 TO 用户名;   GRANT SELECT INSERT DELETE ON表名 TO 用户名 用户名 ;    REVOKE 回收权限   REVOKE CONNECT RESOURCE FROM 用户名;   REVOKE SELECT ON 表名 FROM 用户名; lishixinzhi/Article/program/MySQL/201311/29570


SQL基础语句

/* 语法: select 查询列表 from 表名 特点: 1.查询列表可以是:表中的字段、常量值、表达式、函数 2.查询的结果是虚拟的表格 */ -- 注意查询之前,要打开指定的库,use myemployees; USE myemployees; SELECT last_name FROM employees; SELECT last_name,salary,email FROM employees; SELECT*FROM employees; -- 顺序和表中的字段一样 SELECT 100; SELECT 'JOIN'; SELECT 100*99; SELECT VERSION();-- 8.0.11 /* 好处: 1.便于理解 2.如果要查询的字段有重名的情况,使用别名可以区分开 */ SELECT 100*77 AS 结果 haha; SELECT last_name AS 姓,first_name AS 名 FROM employees; SELECT 100*77 结果 haha; SELECT last_name 姓,first_name 名 FROM employees; -- SELECT salary AS OUT put FROM employees;会报错 -- 因为out是关键词,所以,如果别名里面有关键词的,请加双引号,或者单引号。 SELECT salary AS "OUT put" FROM employees;

上一篇:海信厨卫

下一篇:边潇潇图片