转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> Sql Server >> 正文
ACCESS JET SQL 分段或者交叉统计的查询语句怎么写?         

ACCESS JET SQL 分段或者交叉统计的查询语句怎么写?

作者:闵涛 文章来源:闵涛的学习笔记 点击数:3224 更新时间:2007/11/14 13:13:00

分段或者交叉统计的查询语句怎么写?

作者:cg1  摘自:access911.net  编辑:cg1  更新日期:2006-3-10  浏览人次: 20

专题地址:

http://access911.net/?kbid;72FAB11E1BDCEDF3

 

简述:

分段或者交叉统计的查询语句怎么写?《查询》

 

阅读前需掌握:

 

难度等级:

10


 

 

问题:

 
现在有一个表,结构如下:

 

姓名       班级       科目      分数
王五       初一3班    语文        70
王五       初一3班    数学        80
王五       初一3班    英语        50
周天       初一3班    数学       100
李小       初一2班    语文        99
李小       初一2班    物理       100

想用 JET SQL 语句生成类似以下结构的结果,如何生成?

班级    科目   总分   不及格人次    60到80分人次    80到90分人次    90到100分人次

 

 

 

回答:

 
虽然文字很多,但是并不复杂,请认真仔细查看
上述情况的特点是分段不均匀且可能分段段数很多,比如 60-70 70-80 80-90 90-95 95-100。可以使用 access中的 IIF 和 SWITCH 来实现,但是 access911 推荐使用 jet sql 分步来实现。

 

首先获取第一段的人次(不及格人次)

select 姓名,班级,科目,分数,1 as 不及格人次 from 表 where 分数< 60

但是这样只有一个列显示不及格人次,其他人次没办法显示,其实只要使用一个简单的技巧就可以得到其他列,我们可以用一个固定的数字代表其他列,比如 0

select 姓名,班级,科目,分数,1 as 不及格人次,0 as 60到80分人次,0 as 80到90分人次,0 as 90到100分人次 from 表 where 分数< 60

然后获得获取第二段的人次(60到80分人次)

select 姓名,班级,科目,分数,0 as 不及格人次,1 as 60到80分人次,0 as 80到90分人次,0 as 90到100分人次 from 表 where 分数>=60 and 分数< 80

注意上述语句将固定值“1”移到了“60到80分人次”列,其他列都用固定值“0”代替
好了,这样我们已经得到了两个分段,如何将其组合在一起呢?用 JET SQL 的 UNION ALL 就可以了

select 姓名,班级,科目,分数,1 as 不及格人次,0 as 60到80分人次,0 as 80到90分人次,0 as 90到100分人次 from 表 where 分数< 60 union all
select 姓名,班级,科目,分数,0 as 不及格人次,1 as 60到80分人次,0 as 80到90分人次,0 as 90到100分人次 from 表 where 分数>=60 and 分数< 80

好了,再用同样的原理我们获取所有分段

select 姓名,班级,科目,分数,1 as 不及格人次,0 as 60到80分人次,0 as 80到90分人次,0 as 90到100分人次 from 表 where 分数< 60 union all
select 姓名,班级,科目,分数,0 as 不及格人次,1 as 60到80分人次,0 as 80到90分人次,0 as 90到100分人次 from 表 where 分数>=60 and 分数< 80 union all
select 姓名,班级,科目,分数,0 as 不及格人次,0 as 60到80分人次,1 as 80到90分人次,0 as 90到100分人次 from 表 where 分数>=80 and 分数< 90 union all
select 姓名,班级,科目,分数,0 as 不及格人次,0 as 60到80分人次,0 as 80到90分人次,1 as 90到100分人次 from 表 where 分数>=90 and 分数<=100
 

执行结果如下:

姓名   班级       科目   分数    不及格人次    60到80分人次    80到90分人次    90到100分人次
王五   初一3班    语文     70           &n

[1] [2]  下一页


[Access]sql随机抽取记录  [Access]ASP&SQL让select查询结果随机排序的实现方法
[其他]手工升级ACCESS到SQLSERVER方法详解  [Web开发]把ACCESS的数据导入到Mysql中的方法详解
[系统软件]SQL语句性能优化--LECCO SQL Expert  [C语言系列]SQL Server到DB2连接服务器的实现
[C语言系列]SQL Server到SYBASE连接服务器的实现  [C语言系列]SQL Server到SQLBASE连接服务器的实现
[C语言系列]SQL Server连接VFP数据库的实现  [C语言系列]ASP+SQL Server之图象数据处理
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台