Sql Server 实用函数方法汇总

实用函数方法

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

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

1
2
3
4
5
存储过程中的 '' '' 相当于数据库中的‘ 单引号
DECLARE @str VARCHAR (100)
SET @str= '' 'aaa' ''
SELECT REPLACE (@str, '' '' , '"' )
:"aaa"
1
2
rtrim :使用 LTRIM 删除字符变量中的前导空格 ; RTRIM 删除字符变量中的尾随空格
rtrim(ltrim(splitdata))
1
2
3
4
5
6
7
8
-- 用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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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
1
2
3
4
5
6
7
Return 执行不成功,中断执行
If Exists( select 8 from cb_HsCost where ProjectCode = @ProjectCode and IsJianAn = 1)
    If @ProjectGUID Is Null
     Begin
         Print '[' + @ProjectCode + ']:当前指定的项目在当前系统中不存在!'
         Return -1
     End
1
2
3
得到包含前月在内的一年时间
SET @dtBeginDate = getdate()
SET @dtEndDate = dateadd( month ,-1,dateadd( year ,1,@dtBeginDate))

高能预警

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
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-1,@dt) 
周内的第几日 
select datepart(weekday,getdate()) as 周内的第几日 
年内的第几周 
select datepart(week,getdate()) as 年内的第几周 
年内的第几季 
select datepart(quarter,getdate()) as 年内的第几季

快速高效创建数字辅助表

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
--创建数字辅助表
SET NOCOUNT ON
 
  IF OBJECT_ID( 'dbo.Nums' ) IS NOT NULL DROP TABLE dbo.Nums;
  CREATE TABLE dbo.Nums(n INT NOT NULL PRIMARY KEY );
 
  DECLARE <a href= "http://www.jobbole.com/members/wx2197377149" >@ max </a> AS INT ,@rc AS INT ;
  SET @ max =10000;
  SET @rc=1;
 
  INSERT INTO dbo.Nums VALUES (1);
  WHILE @rc * 2  <a href= "http://www.jobbole.com/members/wx2197377149" >@ max </a>
  BEGIN
  INSERT INTO dbo.Nums SELECT n + @rc FROM dbo.Nums ;
  SET @rc = @rc * 2;
  END
 
  INSERT INTO dbo.Nums
  SELECT n +  @rc FROM dbo.Nums WHERE n + @rc  @ max ;
 
SELECT COUNT (n) FROM Nums

练习:将下面表1每行字符串转化为表2格式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
/*PlanDetailID  Description
1    课程详细安排1,课程详细安排1.1,课程详细安排1.2,课程详细安排1.3
2    课程详细安排2,课程详细安排2.1,课程详细安排2.2
3    课程详细安排3,课程详细安排3.1,课程详细安排3.2,课程详细安排3.3,课程详细安排3.4
4    课程详细安排4
5    课程详细安排5
 
转化为:
PlanDetailID pos Description
1    1    课程详细安排1
1    2    课程详细安排1.1
1    3    课程详细安排1.2
1    4    课程详细安排1.3
2    1    课程详细安排2
2    2    课程详细安排2.1
2    3    课程详细安排2.2
3    1    课程详细安排3
3    2    课程详细安排3.1
3    3    课程详细安排3.2
3    4    课程详细安排3.3
3    5    课程详细安排3.4
4    1    课程详细安排4
5    1    课程详细安排5
*/

参考SQL:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
--生成副本,按逗号的个数,n为逗号的位置(默认第一位为逗号)
SELECT  PlanDetailID ,
         Description ,
         n
FROM    dbo.T_PlanDetail
         INNER JOIN dbo.Nums ON n  LEN(Description) + 1   --若无AND,则表示按字符个数来生成行数
                                AND SUBSTRING ( ',' + Description, n, 1) = ',' ; --将含有逗号时候的行输出
 
--计算每一个字符串的长度
SELECT  PlanDetailID ,
         SUBSTRING (Description, n, CHARINDEX( ',' , Description + ',' , n) - n) AS element --元素的长度等于下一个逗号的位置减该元素的开始位置
FROM    dbo.T_PlanDetail
         INNER JOIN dbo.Nums ON n  LEN(Description) + 1   --若无AND,则表示按字符个数来生成行数
                                AND SUBSTRING ( ',' + Description, n, 1) = ',' ; --将含有逗号时候的行输出
 
--计算每个字符串在数组中的位置,按PlanDetailID 分区,按 n 排序
SELECT  PlanDetailID ,ROW_NUMBER() OVER(PARTITION BY PlanDetailID ORDER BY n) AS pos,
         SUBSTRING (Description, n, CHARINDEX( ',' , Description + ',' , n) - n) AS element
FROM    dbo.T_PlanDetail
         INNER JOIN dbo.Nums ON n  LEN(Description) + 1   --若无AND,则表示按字符个数来生成行数
                                AND SUBSTRING ( ',' + Description, n, 1) = ',' ; --将含有逗号时候的行输出
1
2
3
4
5
6
在sql server中经常有这样的问题:
一个表采用了自动编号的列之后,由于测试了好多数据,自动编号已累计了上万个。
现在正是要用这个表了,测试数据已经删了,遗留下来的问题 就是在录入新的数据,编号只会继续增加,已使用过的但已删除的编号就不能用了,
  谁知道如何解决此问题?
 
truncate 命令不但会清除所有的数据,还会将IDENTITY的SEED的值恢复到原是值。


1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值