- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第8讲多表查询复习与索引.doc.doc
第8讲 索引与函数
一、复习
SELECT 字段1,字段2,...,字段n FROM 表名 WHERE 条件 ORDER BY 字段名 ASC或DESC
在“字段1,字段2,...,字段n”中可以出现count(*),count(列名),sum(列名),avg(列名),MAX(列名),MIN(列名),STDDEV(列名)标准差,VARIANCE(列名)方差即每个值离均值的差。
SELECT 字段1,字段2,...,字段n FROM 表名 WHERE 条件 GROUP BY 分组字段名
使用这些统计函数时,需要加上分组表达式“GROUP BY 字段名”,同组数据相加、求均值等。
子查询复习
SELECT * FROM scoreorigin WHERE endscore-(select avg(endscore) from scoreorigin)10
超过平均值10分以上,不同的比符号,左边运算式有很多表现形式。,=, = = != not (a=b)
SELECT * FROM scoreorigin WHERE endscore=(SELECT max(endscore) FROM scoreorigin)
等于最高分,子查询可有以有很多的形式,=可有很多变化,字段名endscore可以换成其他字段。
SELECT * FROM scoreorigin WHERE studname=(SELECT max(studname) FROM scoreorigin)
等于姓名最大者
以下4个查询获取最大和、平均值、最大值、最小值
select sum(middlescore) from scoreorigin
SELECT avg(middlescore) FROM scoreorigin
SELECT max(middlescore) from scoreorigin
SELECT min(middlescore) FROM scoreorigin
以下兰色的字是查询的整体语句,红色的字是分别计算总和、最大值、最小值、平均值的子查询,它可以出现在SELECT部分,也可以出现在WHERE部分。
SELECT id,studno,studname,deptname,teachername, coursename, middlescore, (select sum(middlescore) from scoreorigin),(SELECT max(middlescore) from scoreorigin) FROM scoreorigin
WHERE middlescore(SELECT min(middlescore) FROM scoreorigin) AND middlescore(SELECT avg(middlescore) from scoreorigin)
= != = =
以上样例的子查询的结果只有一个值。
SELECT * FROM scoreorigin WHERE studno in (SELECT studno FROM scoreorigin WHERE NOT (deptname like %新%) )
红色字段可以换成其11个字段之一,兰色的条件中deptname可以换成char型字段,如studname,studno, teachername, coursename。 LIKE后面的表达式,更可以灵活变化。
SELECT * FROM scoreorigin WHERE testscore2 in (SELECT testscore1 FROM scoreorigin WHERE testscore180)
学院名称 deptname
红色字段可以换成其11个字段之一,兰色的条件中testscore1可以换成decimal,int,float,double型字段,如testscore2,...,totalscore。 可换成,=,=,=,!, 还可以testscore1=60 and testscore280或testscor160 or testscore1=80,可以变出很多花样。
以上各例,子查询返回的结果不止一个!所以要换成“in”,表示:学号studno在返回结果中。
SELECT teacherno,teachername FROM teachertable WHERE EXISTS (SELECT * FROM score WHERE teachertable.teacherno=score.teachername)
最关键语句
teachertable.teacherno=Score.teachername
它表明二个表之间的关系,两个表此列数据相同,基
文档评论(0)