数据字段如下
字段名 DayID Week IsJobDay
存贮的值 20080101 二 1
20080102 三 1
20080103 四 1
20080104 五 1
20080105 六 0
20080101 日 0如何将上面这样类型的表查询为
这个下面这个列表样式的年月 当月数 工作日 非工作日2008年01月 31 13 18
2008年02月 29 21 8
2008年03月 31 20 11我的语句是这样的 前两列的值都查出来了
但就是第三列不知道该怎么办了
于是就注释掉了
谁帮帮我??select
substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月'
as yearmonth,
count(substring(dayid,7,2))
as days
--(select count(isjobday) from jobday j where isjobday=1
--and substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月' = )
-- as days1
from jobday
group by
substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月'
字段名 DayID Week IsJobDay
存贮的值 20080101 二 1
20080102 三 1
20080103 四 1
20080104 五 1
20080105 六 0
20080101 日 0如何将上面这样类型的表查询为
这个下面这个列表样式的年月 当月数 工作日 非工作日2008年01月 31 13 18
2008年02月 29 21 8
2008年03月 31 20 11我的语句是这样的 前两列的值都查出来了
但就是第三列不知道该怎么办了
于是就注释掉了
谁帮帮我??select
substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月'
as yearmonth,
count(substring(dayid,7,2))
as days
--(select count(isjobday) from jobday j where isjobday=1
--and substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月' = )
-- as days1
from jobday
group by
substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月'
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDay]') and xtype in (N'FN', N'IF', N'TF'))
drop function [dbo].[f_WorkDay]
GO--计算两个日期相差的工作天数
CREATE FUNCTION f_WorkDay(
@dt_begin datetime, --计算的开始日期
@dt_end datetime --计算的结束日期
)RETURNS int
AS
BEGIN
DECLARE @workday int,@i int,@bz bit,@dt datetime
IF @dt_begin>@dt_end
SELECT @bz=1,@dt=@dt_begin,@dt_begin=@dt_end,@dt_end=@dt
ELSE
SET @bz=0
SELECT @i=DATEDIFF(Day,@dt_begin,@dt_end)+1,
@workday=@i/7*5,
@dt_begin=DATEADD(Day,@i/7*7,@dt_begin)
WHILE @dt_begin<=@dt_end
BEGIN
SELECT @workday=CASE
WHEN (@@DATEFIRST+DATEPART(Weekday,@dt_begin)-1)%7 BETWEEN 1 AND 5
THEN @workday+1 ELSE @workday END,
@dt_begin=@dt_begin+1
END
RETURN(CASE WHEN @bz=1 THEN -@workday ELSE @workday END)
END
GO/*=================================================================*/if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_WorkDayADD]') and xtype in (N'FN', N'IF', N'TF'))
drop function [dbo].[f_WorkDayADD]
GO--在指定日期上,增加指定工作天数后的日期
CREATE FUNCTION f_WorkDayADD(
@date datetime, --基础日期
@workday int --要增加的工作日数
)RETURNS datetime
AS
BEGIN
DECLARE @bz int
--增加整周的天数
SELECT @bz=CASE WHEN @workday<0 THEN -1 ELSE 1 END
,@date=DATEADD(Week,@workday/5,@date)
,@workday=@workday%5
--增加不是整周的工作天数
WHILE @workday<>0
SELECT @date=DATEADD(Day,@bz,@date),
@workday=CASE WHEN (@@DATEFIRST+DATEPART(Weekday,@date)-1)%7 BETWEEN 1 AND 5
THEN @workday-@bz ELSE @workday END
--避免处理后的日期停留在非工作日上
WHILE (@@DATEFIRST+DATEPART(Weekday,@date)-1)%7 in(0,6)
SET @date=DATEADD(Day,@bz,@date)
RETURN(@date)
END
count(*) as 当月数,
工作日=sum(case IsJobDay when 1 then 1 else 0 end),
非工作日=sum(case IsJobDay when 0 then 1 else 0 end)
from jobday
group by
substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月'
加聚合函数啦 工作日=sum(case IsJobDay when 1 then 1 else 0 end),
非工作日=sum(case IsJobDay when 0 then 1 else 0 end)
-- Author :fredrickhu(小F 向高手学习)
-- Date :2009-07-27 21:33:12
----------------------------------------------------------------
--> 测试数据:[tb]
if object_id('[tb]') is not null drop table [tb]
create table [tb]([DayID] varchar(50),[Week] varchar(2),[IsJobDay] int)
insert [tb]
select '20080101','二',1 union all
select '20080102','三',1 union all
select '20080103','四',1 union all
select '20080104','五',1 union all
select '20080105','六',0 union all
select '20080101','日',0
--------------开始查询--------------------------
select
substring(dayid ,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月' as yearmonth,
count(*) as 当月数,
工作日=sum(case IsJobDay when 1 then 1 else 0 end),
非工作日=sum(case IsJobDay when 0 then 1 else 0 end)
from
tb
group by
substring(dayid ,1,4)+' '+'年'+' '+substring(dayid ,5,2)+' '+'月'
----------------结果----------------------------
/*yearmonth 当月数 工作日 非工作日
------------------- ----------- ----------- -----------
2008 年 01 月 6 4 2(所影响的行数为 1 行)
*/