第8讲多表查询复习与索引.doc.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 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)

youbika + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档