(排班表一)使用SQL语句使数据从坚向排列转化成横向排列
知识重点:
1.extract(day from schedule01::timestamp)=13
Extract 属于 SQL 的 DML(即数据库管理语言)函数,同样,InterBase 也支持 Extract,它主要用于从一个日期或时间型的字段内抽取年、月、日、时、分、秒数据,因此,它支持其关健字 YEAR、MONTH、DAY、HOUR、MINUTE、SECOND、WEEKDAY、YEARDAY。
Extract 的使用语法为:
EXTRACT(关健字 FROM 日期或时间型字段)
如:extract(year from schedule01)=2017从日期中提取年份
2.max()函数:取最大值
3.case()函数的嵌套
注意嵌套case()函数时,每个case的开始和结束。
排班功能:现有两个人员(A和B),他们在不同日期的值班状态(state)不同,现在要查询他们在2017.6月的值班信息
表结构如下:
CREATE TABLE public.temp_schedule
(
id integer NOT NULL DEFAULT nextval('temp_schedule_id_seq'::regclass),
schedule01 timestamp without time zone,--日期
schedule03 character varying(),--姓名
state character varying(),--值班状态(0休 1班)
CONSTRAINT temp_schedule_pkey PRIMARY KEY (id)
)
1.查询SQL语句:
select schedule03,schedule01,state from temp_schedule where extract(year from schedule01)= and extract(month from schedule01)= order by schedule03,schedule01;
显示为:

2.现在需要根据(6月的)日期,从1号开始根据人员名称横向合并排列数据(即只显示两行)
显示效果如下:

实现的SQL语句如下:
select schedule03 as name ,max(case when extract(day from schedule01::timestamp)= then state end) as day1 ,max(case when extract(day from schedule01::timestamp)= then state end) as day2 ,max(case when extract(day from schedule01::timestamp)= then state end) as day3 ,max(case when extract(day from schedule01::timestamp)= then state end) as day4 ,max(case when extract(day from schedule01::timestamp)= then state end) as day5 ,max(case when extract(day from schedule01::timestamp)= then state end) as day6 ,max(case when extract(day from schedule01::timestamp)= then state end) as day7 ,max(case when extract(day from schedule01::timestamp)= then state end) as day8 ,max(case when extract(day from schedule01::timestamp)= then state end) as day9 ,max(case when extract(day from schedule01::timestamp)= then state end) as day10 ,max(case when extract(day from schedule01::timestamp)= then state end) as day11 ,max(case when extract(day from schedule01::timestamp)= then state end) as day12 ,max(case when extract(day from schedule01::timestamp)= then state end) as day13 from temp_schedule where extract(year from schedule01)= and extract(month from schedule01)= group by schedule03;
3.将人员的值班状态通过汉字(0休 1班)显示出来,显示效果如下:

SQL语句(主要是实现case的嵌套):
select schedule03 as name ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day1 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day2 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day3 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day4 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day5 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day6 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day7 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day8 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day9 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day10 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day11 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day12 ,max(case when extract(day from schedule01::timestamp)= then (case when state='' then '休' else '班' end) end) as day13 from temp_schedule where extract(year from schedule01)= and extract(month from schedule01)= group by schedule03 ;
知识一点点的累积,技术一点点的提高!加油!
(排班表一)使用SQL语句使数据从坚向排列转化成横向排列的更多相关文章
- 使用SQL语句使数据从坚向排列转化成横向排列(排班表)
知识重点: 1.extract(day from schedule01::timestamp)=13 Extract 属于 SQL 的 DML(即数据库管理语言)函数,同样,InterBase 也支持 ...
- 用SQL语句将数据表中的数据保存为JSON格式
没有找到好的工具,只想到了拼字符串的方式,用 NVARCHAR(MAX) 可能有截断,不推荐使用,方法中使用了 FOR XML PATH('') 实现,有关其使用方法参考这里 表结构: SQL ...
- Hibernate原生SQL查询多表关联,SQL语句要注意的问题
Hibernate原生SQL查询多表关联,SQL语句要注意的问题 @for&ever 2009-9-4 系统环境: MySQL5.1 Hibernate3.3 有如下的假定: 实体类 Ques ...
- (排班表二)后台动态绘制Grid表格
后台动态绘制值班表(Grid表格 列名不固定) 要求:表头除了值班人姓名,还要显示日期,及每天的星期值,用斜杠‘/’分隔.即:几号/星期几 最终实现的效果:根据查询的年月显示每个值班人查询月份每天的值 ...
- 监控SQL:执行表中所有sql语句、记录每个语句运行时间(3)
原文:监控SQL:执行表中所有sql语句.记录每个语句运行时间(3) 通过执行一个 带参数的存储过程 exec OpreateTB('OpreateUser','IsRun') 更新表的数据 表 ...
- 通过MyEclipse操作数据库,执行sql语句使我们不用切换多个工具,直接工作,方便快捷
通过MyEclipse操作数据库,执行sql语句使我们不用切换多个工具,直接工作,方便快捷.效果如下: 步骤1:通过MyEclipse中的window->show View->ot ...
- SQL语句之 数据约束
SQL语句之 数据约束 什么是数据约束 数据约束用来限制用户对数据的非法的修改操作. 1.约束字段的默认值 如果插入记录时,没有给某个字段赋值,那么我们可以设置它的默认值 关键字:default CR ...
- PHP如何通过SQL语句将数据写入MySQL数据库呢?
1,php和MySQL建立连接关系 2,打开 3,接受页面数据,PHP录入到指定的表中 1.2两步可直接使用一个数据库链接文件即可:conn.php <?phpmysql_connect(&qu ...
- 通过Sql语句导数据
在通过SQL Server向导中的SQL语句导数据时,默认情况下源表中的nvarchar字段类型会变成202,解决此问题的方法是,要重新选择一下对应的数据接收表.
随机推荐
- python单元测试框架-unittest(一)
简介 unittest单元测试框架不仅可以适用于单元测试,还可以使用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果. ...
- bootstrap3-dialog:更强大、更灵活的模态框(封装好的模态框)
用过bootstrap框架的同学们都知道,bootstrap自带的模态框用起来很不灵活,可谓鸡肋的很.但nakupanda开源作者封装了一个更强大.更灵活的模态框——bootstrap3-dialog ...
- jQuery源代码学习笔记_01
如何获取jQuery源代码 1.可以从GitHub上下载到没有合并和压缩的源代码 2.如果要查看兼容IE6-8的版本,请选择1.x-master分支 3.可以使用git clone也可以使用downl ...
- Tomcat安装和配置过程
tomcat的下载.配置.启动方法.网上教程乱七八糟,还是自己mark一下备用吧. 一.官网下载Tomcat的压缩包 Tomcat是Apache软件基金会的一个开源项目.登录Apache官网即可找到下 ...
- c++关于map的find和count的使用
编程的时候比较常用,今天记录一下,以后备用. 使用count,返回的是被查找元素的个数.如果有,返回1:否则,返回0.注意,map中不存在相同元素,所以返回值只能是1或0. 使用find,返回的是被查 ...
- MVC HtmlHelper listbox用法
主要实现MVC listbox左右移动,搜索左边用户 controller List<userinfo> lstUserInfo = new List<userinfo>( ...
- grunt项目构建
最近想把项目里添加grunt,说白了就是前端自动化管理,具体配置如下: 用到以下几个部件: grunt-contrib-cssmin grunt-contrib-uglify grunt-contri ...
- GitHub安装缓慢甚至下载失败的解决办法
1.打开控制面板→ Internet 选项→“安全”选项卡. 2.选择“受信任的站点”→点击“站点”按钮. 3.弹出的窗口中的文本框中输入点击“添加” https://github-windows.s ...
- php session 存储到redis
PHP 的会话默认是以文件的形式存在的,可以配置到 NoSQL 中,即提高了访问速度,又能很好地实现会话共享,,,爽歪歪! 配置方式如下: 方法一:修改 php.ini 的设置 1 2 session ...
- (八)JavaScript之[JSON]与[void]
14].JSONJSON 格式在语法上与创建 JavaScript 对象代码是相同的. 方法:JSON.parse(); //将JSON字符串转换为JavaScript对象JSON.stringify ...