2017.03.22:数据库SQL语句

Student(SId,Sname,Sage,Ssex)           学生表(学号、姓名、年龄、性别)

Course(CId,Cname,TId)                课程表(课程编号、课程名字、教师编号)

SC(SId,CId,score)                     成绩表(学号、课程编号、成绩)

Teacher(TId,Tname)                   教师表(教师编号、教师名字)

1. having: 对由sum或其他集合函数运算结果的输出进行限制。

e.g. 查询平均成绩大于60分的同学的学号和平均成绩

select SId,ave(score) from sc group by SId having(score)>60

2. LEFT JOIN: 关键字会从左表(table_name1) 那里返回所有的行,即使在右表(table_name2) 中没有匹配的行。

e.g. 查询所有同学的学号、姓名、选课数、总成绩

select Student.SId,Student.Sname,count(SC.CId),sum(score) fromStudent left Outer join SC on Student.SId=SC.SId group by Student.SId,Sname

3. WHERE 子句不能包含聚集函数; 因为试图用聚集函数判断那些行输入给聚集运算是没有意义的。 相反,HAVING 子句总是包含聚集函数。

4. CONVERT() 函数是把日期转换为新数据类型的通用函数。CONVERT()函数可以用不同的格式显示日期/时间数据。

e.g. 1981年出生的学生名单(注:Student表中Sage列的类型是datetime)

select Sname, CONVERT(char (11),DATEPART(year,Sage)) as age fromstudent where CONVERT(char(11),DATEPART(year,Sage))='1981';

5. 微软的ISNULL() 函数用于规定如何处理 NULL 值。

e.g. 查询课程名称为“数据库”,且分数低于60的学生姓名和分数

Select Sname,isnull(score,0) from Student,SC,Course whereSC.SId=Student.SId and SC.CId=Course.CId and Course.Cname='数据库'and score <60;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值