数据库 一步步处理 行列转换

php中文网
发布: 2016-06-07 17:37:34
原创
1178人浏览过

做个东西,发现了些问题,又解决了,很Happy! 数据库有2个表: [省份表],2列(provinceId--省的id,provinceName--省名字), [公司表],好几列(companyId--公司Id,provinceId--公司所在省id,recruitType--这个招聘会类型(只有1,2,3这三个值,每个值一个含义),......其

做个东西,发现了些问题,又解决了,很happy!

数据库有2个表:

[省份表],2列(provinceId--省的id,provinceName--省名字),

[公司表],好几列(companyId--公司Id, provinceId--公司所在省id, recruitType--这个招聘会类型(只有1,2,3这三个值,每个值一个含义),......其他问题无关列)

------------------------------------------------------------------------------------------------

MVM mall 网上购物系统
MVM mall 网上购物系统

采用 php+mysql 数据库方式运行的强大网上商店系统,执行效率高速度快,支持多语言,模板和代码分离,轻松创建属于自己的个性化用户界面 v3.5更新: 1).进一步静态化了活动商品. 2).提供了一些重要UFT-8转换文件 3).修复了除了网银在线支付其它支付显示错误的问题. 4).修改了LOGO广告管理,增加LOGO链接后主页LOGO路径错误的问题 5).修改了公告无法发布的问题,可能是打压

MVM mall 网上购物系统 0
查看详情 MVM mall 网上购物系统

方法一:(自己写的)

------------------------------------------------------------------------------------------------

我想获得的结果,即每个省按那三个招聘会类型统计各种类型公司的总数,如下:

------------------------------------------------------------------------------------------------

先获得了下面表,省id,招聘会类型,公司总数,这是在[公司表]里面按(省id,招聘会类型)group by和count()得到的,注意这里有个问题,就是[公司表]里面不是什么省份的都有,所以provinceId是不连续的,所以要在后面处理.

------------------------------------------------------------------------------------------------

然后联合[省份表],得到下面的表,这个很容易,只要注意一下 left join,就可以显示所有的省份了

------------------------------------------------------------------------------------------------

现在问题来了,我想显示的目标图是第一个图,就是这么把那些相同省的行合并为同一行,并且有三个列分别显示那三种招聘会类型的公司总数?

我想了半天,因为最终是要在Web上显示的,我想要不就在数据库搞好,把结果直接返回,Web端就不要处理什么了,要不就这样返回吧,在Web端合并相同的行,

但最后发现还是数据库端好处理,因为T-SQL很强大,并且Web端处理这些表格很麻烦,我不知道它那些DataTable啊什么的类似怎么样构造的,遂选择在数据库端处理.

------------------------------------------------------------------------------------------------

1,建立最后想要结果的表,把目标列写好,然后要不insert,要不update

2,用游标一个一个处理上面的那个表,provinceId一样的就update那一行几个值,否则insert新行

3,最后处理一些数据,得到想要结果:

代码量大啊!!!主要用游标一行一行处理的......

ANSI_NULLS QUOTED_IDENTIFIER -- Author: -- Create date: -- Description: 按招聘单位地域统计的数据源 --.(10), @timeTo char(20) (N,N) #tableTemp .provinceId , .recruitType ,COUNT(*) as companySum .recruitTime .provinceId,.recruitType .provinceId (N,N) #newTable .provinceId,.provinceName,#tableTemp.recruitType,#tableTemp.companySum #tableTemp .provinceId=#tableTemp.provinceId .provinceId (N,N) #lastTable #lastTable --创建表最终要返回应用程序的表!!!!注意这里的强大之处!!! ( provinceId , provinceName nvarchar(20) not null, type1Sum , --默认值为0,省去null处理的麻烦 type1Ratio varchar(10), type2Sum , type2Ratio varchar(10), type3Sum , type3Ratio varchar(10), allTypeSum , allTypeRatio varchar(10) ) ,,curToNewTable scroll #newTable open curToNewTable () () #lastTable (provinceId,provinceName) values (@provinceId,@provinceName) ) insert into #lastTable (provinceId,provinceName,type1Sum) values(@provinceId,@provinceName,@companySum) ) insert into #lastTable (provinceId,provinceName,type2Sum) values(@provinceId,@provinceName,@companySum) #lastTable (provinceId,provinceName,type3Sum) values(@provinceId,@provinceName,@companySum) () #lastTable #lastTable.provinceId() #lastTable.provinceId() #lastTable.provinceIdcurToNewTable curToNewTable curToNewTable ,,(select sum(type1Sum) from #lastTable) (select sum(type2Sum) from #lastTable) (select sum(type3Sum) from #lastTable) ,,curToFillRatio scroll type1Sum,type2Sum,type3Sum curToFillRatio () ((() () () () ((((4,1)) ((4,1)) ((4,1)) ((4,1)) #lastTable (, type2Ratio(, type3Ratio(, allTypeSum=@lineTypeAllSum, allTypeRatio( curToFillRatio curToFillRatio curToFillRatio deallocate curToFillRatio #lastTable ,, , , ) ( #lastTable allTypeSum )T #lastTable

我的一步步处理代码

 

------------------------------------------------------------------------------------------------

方法二:(得到的答案)

------------------------------------------------------------------------------------------------

这里的主要问题就是把有那个有多行省Id是一样的合并到一行中去,添加了列

神伤中......居然可以这么简单......

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号