数据字段如下
字段名       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)+' '+'月' 

解决方案 »

  1.   

    参考工作日
    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
      

  2.   

    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 jobday 
        group by 
            substring(dayid,1,4)+' '+'年'+' '+substring(dayid,5,2)+' '+'月' 
      

  3.   


      加聚合函数啦        工作日=sum(case IsJobDay when 1 then 1 else 0 end),
            非工作日=sum(case IsJobDay when 0 then 1 else 0 end)
      

  4.   

    ----------------------------------------------------------------
    -- 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 行)
    */