知识重点:
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月的值班信息
表结构如下:
1 CREATE TABLE public.temp_schedule2
3 (4
5 id integer NOT NULL DEFAULT nextval('temp_schedule_id_seq'::regclass),6
7 schedule01 timestamp without time zone,--日期8
9 schedule03 character varying(255),--姓名10
11 state character varying(255),--值班状态(0休 1班)12
13 CONSTRAINT temp_schedule_pkey PRIMARY KEY (id)14
15 )
View Code
1.查询SQL语句: