解决SQL Server中Group无法实现的问题

在前一段时间中遇到一个需求..统计某一种商品在某一天中的销售数量,当天没有销售的时候,数量显示0.

这个不能用一般的Group来实现.所以需要变通一下,跟一个有1-31的一个集合来Group.

有2种方案.

planA:

  1. SELECT SUM(ISNULL(BidsTrade_Money, 0))   
  2. AS [MONEY], a.number   
  3. AS [DAY]FROM MASTER..spt_values a      
  4. LEFT JOIN DDPM_T_Comm_BidsTrade b          
  5. ON  a.type = 'p'             
  6.  AND month([BidsTrade_DateCreated])='5'              
  7. AND a.number = DAY(b.[BidsTrade_DateCreated])              
  8. AND YEAR([BidsTrade_DateCreated]) = '2010'              
  9. WHERE a.number BETWEEN 1 AND 31GROUP BY a.numberorder by DAY 

使用MASTER..spt_values(产生一定范围的数字的数字,这里需要产生1-31的数字.)

但是这一种方法有缺陷,每一个月不一定都是31天.并且我们配置的SQL账号不一定有权限来访问这个函数.

planB:.通过自定义函数.

自定义函数GetOrderType(比较长- -..)

  1. CREATE function [dbo].[CN80s_FN_GetOrderType](    @tabName nvarchar(2000),      
  2. @keyOrder nvarchar(255))returns nvarchar(100)asbegin    declare @OrderTable nvarchar(255)  --表名     
  3.  declare @OrderName nvarchar(255)  --字段名      
  4. declare @OrderType nvarchar(255)  --字段类型      
  5. declare @OrderPrec nvarchar(50)  --字段长度      
  6. declare @OrderDot int  --点的位置      
  7. declare @s1 nvarchar(100) -- 临时变量1      
  8. declare @s2 nvarchar(100) -- 临时变量2    --去除排序规则    
  9. set @keyorder=REPLACE(@keyorder, ' asc', '')    --求表名、字段名      
  10. set @OrderDot=CHARINDEX('.', @keyorder)      
  11. IF @OrderDot > 0          
  12. BEGIN              
  13. SET @OrderTable = SUBSTRING(@keyorder, 0, @OrderDot)              
  14. SET @OrderName = SUBSTRING(@keyorder, @OrderDot + 1, LEN(@keyorder))         
  15. END      
  16. ELSE          
  17. BEGIN              
  18. SET @OrderTable = @tabName              
  19. SET @OrderName = @keyorder          
  20. END    --去除方括号    set @s1=REPLACE(REPLACE (@OrderTable,'[',''),']','')      
  21. set @s2=REPLACE(REPLACE (@OrderName,'[',''),']','')    --求字段类型、字段长度      
  22. SELECT @OrderType=t.[name], @OrderPrec=c.prec      
  23. FROM sysobjects o       
  24. JOIN syscolumns c on o.id=c.id      
  25. JOIN systypes t on c.xusertype=t.xusertype      
  26. WHERE o.name = @s1 AND c.[name] = @s2      
  27. if @OrderType is null    begin          
  28. SET @OrderType='Sql_Variant'      
  29. end    else    begin          
  30. IF CHARINDEX('char', @OrderType) > 0             
  31. SET @OrderType = @OrderType + '(' + CAST(@OrderPrec AS nvarchar) + ')'      
  32. end    return @OrderTypeendGO 

函数2(这个更长) 

USE[CN80s.DDPM]
GO

/****** Object: UserDefinedFunction [dbo].[FormatDateTime] Script Date: 08/01/2010 16:28:23 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO



CREATEfunction[dbo].[FormatDateTime](@Datedatetime,@formatStrvarchar(20))
returnsvarchar(16)
as
begin
declare@tempstrvarchar(20),@indexint,@retStrvarchar(20),@formatLenint,@str1varchar(6),@str2varchar(6),@str3varchar(6),@jint
declare@tempformatvarchar(20)
select@tempformat=@formatStr,@formatStr=Upper(@formatStr),@index=-1,@retstr=''
if@formatStr='MM/DD/YYYY'
set@retstr=convert(varchar(10),@date,101)
elseif@formatstr='YYYY-MM-DD'
set@retstr=Convert(char(10),@Date,20)
elseif@formatStr='YYYY.MM.DD'
set@retstr=Convert(varchar(10),@Date,102)
elseif@formatStr='YYYY/MM/DD'
set@retstr=Convert(varchar(10),@Date,111)
elseif@formatStr='DD/MM/YYYY'
set@retstr=Convert(varchar(10),@Date,103)
elseif@formatStr='DD.MM.YYYY'
set@retstr=Convert(varchar(10),@Date,104)
elseif@formatStr='DD-MM-YYYY'
set@retstr=Convert(varchar(10),@Date,105)
elseif@formatStr='YYYYMMDD'
set@retstr=Convert(varchar(10),@Date,112)
else
begin
select@tempformat=@formatStr,@formatLen=len(@formatStr)
if@formatLen>8
begin
set@index=charindex('M',@tempformat)
select@str1=right(left(@tempformat,@index-1),@index-5),@str2=right(@tempformat,@formatLen-@index-1)
select@index=charindex('D',@str2),@str3=@str2
set@str2=left(@str2,@index-1)
set@str3=right(@str3,len(@str3)-@index-1)
end
select@tempstr=Convert(char(10),@Date,20),@str1=isnull(@str1,''),@str2=isnull(@str2,''),@str3=isnull(@str3,''),@j=0
while@index<>0
begin
set@index=charindex('-',@tempstr)
if@j=0
select@retstr=left(@tempstr,@index-1)+@str1,@j=@j+1
elseset@retstr=@retstr+left(@tempstr,@index-1)+@str2
select@tempstr=right(@tempstr,len(@tempstr)-@index)
set@index=charindex('-',@tempstr)
end
set@retstr=@retstr+@tempstr+@str3
end
return@retstr
end


GO

可以看看调用这个函数的结果.

  1. SELECT * FROM CN80s_DDPM_FN_GETDATE('2010-05-1','2010-05-31',null

参数依次为:开始时间,结束时间,显示状态(null:显示所有日期,0显示所有工作日(星期一~星期五),1:显示周末,2显示周末)

当然这个函数有其他的扩展应用请各位看官天马行空.~

实际应用,这里写了一个存储过程 

  1. SELECT a.day , isnull(BidsCombo_Price,0) as   
  2. BidsCombo_Price, isnull( BidsTrade_Count,0) as    
  3. BidsTrade_CountFROM (          
  4. SELECT year(Dateas year,month(Dateas month,day(Dateas [day
  5. FROM dbo.CN80s_DDPM_FN_GETDATE(@beginTime,@endTime,NULL) ) a       
  6. LEFT JOIN          
  7. DDPM_V_BidsTradeRecount b         
  8.  ON  a.day = b.day          
  9. AND a.year=b.year          
  10. AND a.month=b.month    GO 

原文标题:一个SQL Group问题

链接:http://www.cnblogs.com/willsonchan/archive/2010/08/01/1789980.html

【编辑推荐】

  1. SQL Server数据库和Oracle行转列的特殊方案描述
  2. SQL Server行转列的什么情况下被用?
  3. SQL Server实例中对另个实例的调用
  4. SQL Server identity列,美中不足之处
  5. SQL Server DateTime数据类型的另类解读

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/262662.html<

(0)
运维的头像运维
上一篇2025-05-04 05:08
下一篇 2025-05-04 05:10

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注