http://www.cnblogs.com/zhangs1986/p/4917800.html
实用函数方法
由于有些知识很少被用到,但真需要用时却忘记了又焦头烂额的到处找。
现在将这些‘冷门“却有效的小知识贡献出来,以备不时之需。
存储过程中的 '''' 相当于数据库中的‘ 单引号
DECLARE @str VARCHAR(100)
SET @str='''aaa'''
SELECT REPLACE(@str,'''','"')
:"aaa"
rtrim :使用 LTRIM 删除字符变量中的前导空格 ; RTRIM 删除字符变量中的尾随空格
rtrim(ltrim(splitdata))
-- 用select into 把数据放到临时表中,按交费期限排序,并加上id
select identity(int,1,1) as id,FeeGUID,PayLimit,BgnDate,EndDate,Amount,TestIsRight
into #tmpfee --select into不需要提前声明临时表#tmpfee
from z_fee
where RentGUID = @strRentGUID
order by PayLimit
drop table #tmpfee
用insert into select 创建临时表 插入自增列
Create Table #Temp_ProjectCodeList
(
RowId int identity(1,1)
,ProjectCode varchar(100)
)
Insert Into #Temp_ProjectCodeList(ProjectCode)
Select ProjCode From p_Project Where Level = 2
Set @MaxCount = @@RowCount
Set @Count = 1
While @Count <= @MaxCount
Begin
Select @ProjectCode = ProjectCode From #Temp_ProjectCodeList Where RowId = @Count
Exec usp_cb_BuildHsCost @ProjectCode, @IsExistHsCost, @IsUpdateCsCost
--调整计数器
Set @Count = @Count + 1
End
Return 执行不成功,中断执行
If Exists(select 8 from cb_HsCost where ProjectCode = @ProjectCode and IsJianAn = 1)
If @ProjectGUID Is Null
Begin
Print '[' + @ProjectCode + ']:当前指定的项目在当前系统中不存在!'
Return -1
End
得到包含前月在内的一年时间
SET @dtBeginDate = getdate()
SET @dtEndDate = dateadd(month,-1,dateadd(year,1,@dtBeginDate))
高能预警
DATEPART ( datepart , date ) datepart函数中一周是周日到周六,而我们通常认为一周是周一到周日
返回表示指定日期的指定日期部分的整数
本周第一天 (星期1)
select dateadd(wk, datediff(wk,0,getdate()), 0)
本周最后一天(星期天)
select dateadd(wk, datediff(wk,0,getdate()), 6)
得到上周一的日期:
SELECT DATEADD(day,-DATEPART(weekday,getdate())-5,getdate())
得到上周日的日期:
SELECT DATEADD(day,-DATEPART(weekday,getdate())+1,getdate())
得到上个月月末日期:
SELECT dateadd(day,-datepart(day,getdate()),getdate())
上月第一天
SELECT CONVERT(CHAR(10),DATEADD(month,-1,DATEADD(dd,-DAY(GETDATE())+1,GETDATE())),111)
本月第一天
select dateadd(dd,-datepart(dd,getdate())+1,getdate())
本月最后一天(当前为2011-03-31时会出错) 选用:select dateadd(dd,-DAY(dateadd(mm,1,'2011-12-20')) ,dateadd(mm,1,'2011-12-20'))
select dateadd(dd,-datepart(dd,getdate()) ,dateadd(mm,1,getdate()))
下月第一天
select dateadd(dd,-datepart(dd,getdate())+1,dateadd(mm,1,getdate()))
下月最后一天
SELECT CONVERT(CHAR(10),DATEADD(ms,-3,DATEADD(mm,DATEDIFF(m,0,getdate())+2,0)),111)+' 23:59:59'
季度第一天
SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)
季度最后一天(直接推算法)
SELECT DATEADD(Day,-1,CONVERT(char(8),DATEADD(Month,1+DATEPART(Quarter,getdate())*3-Month(getdate()),getdate()),120)+'1')
季度的最后一天(CASE判断法)
select DATEADD(Month,DATEPART(Quarter,getdate())*3-Month(getdate()),getdate())
本月第一个星期一
SELECT DATEADD(wk, DATEDIFF(wk, '', DATEADD(dd, 6 - DAY(getdate()), getdate())), '')
今年第一天
SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
今年最后一天
SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1,0))
指定日期所在周的任意一天
SELECT DATEADD(Day,@number-DATEPART(Weekday,@dt),@dt)--5.指定日期所在周的任意星期几
A. 星期天做为一周的第1天
SELECT DATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-1)%7,@dt)
B. 星期一做为一周的第1天
SELECT DATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-2)%7