博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
你真的会玩SQL吗?实用函数方汇总
阅读量:6186 次
发布时间:2019-06-21

本文共 2951 字,大约阅读时间需要 9 分钟。

 

实用函数方法

由于有些知识很少被用到,但真需要用时却忘记了又焦头烂额的到处找。

现在将这些‘冷门“却有效的小知识贡献出来,以备不时之需。

 

存储过程中的 '''' 相当于数据库中的‘ 单引号DECLARE @str VARCHAR(100) SET @str='''aaa''' SELECT REPLACE(@str,'''','"') :"aaa"

 

rtrim :使用 LTRIM 删除字符变量中的前导空格 ; RTRIM 删除字符变量中的尾随空格rtrim(ltrim(splitdata))

 

-- 用select into 把数据放到临时表中,按交费期限排序,并加上idselect 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)

转载地址:http://ngada.baihongyu.com/

你可能感兴趣的文章
RabbitMQ安装
查看>>
django 学习笔记 (五)
查看>>
iOS UItableviewCell实现可变高度的UITextView,动态刷新高度
查看>>
iOS开发- 利用runtime拦截UIButton的点击事件,防止重复点击
查看>>
Java,Jsp获取客户端IP地址
查看>>
100-88
查看>>
android4.0.3 编译lichee 报错dhd-cdc-sdmmc-gpl-3.0.8问题
查看>>
crc16 - 产生Modbus RTU格式的CRC码
查看>>
招聘又来了,这次推荐有奖哦
查看>>
我的友情链接
查看>>
Linux下ssh秘钥方式登录远程服务器
查看>>
golang test测试使用
查看>>
【Apache学习】编译安装httpd2.4 含傻瓜版自动安装脚本
查看>>
Python classmethod(类方法) 和 类属性 静态方法(缺少)
查看>>
我的友情链接
查看>>
vsftpd的基于pam_mysql的虚拟用户配置示例
查看>>
C语言中运算符的优先级排序
查看>>
nodejs tutorial - 5 单元测试 2015-3-24
查看>>
ubuntu下未获得锁问题
查看>>
我的友情链接
查看>>