实用函数方法
由于有些知识很少被用到,但真需要用时却忘记了又焦头烂额的到处找。
现在将这些‘冷门“却有效的小知识贡献出来,以备不时之需。
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的值恢复到原是值。 |