日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

[收藏]整理了一些T-SQL技巧

發(fā)布時間:2025/5/22 数据库 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [收藏]整理了一些T-SQL技巧 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
[收藏]整理了一些T-SQL技巧一、?只復(fù)制一個表結(jié)構(gòu),不復(fù)制數(shù)據(jù)
二、?獲取數(shù)據(jù)庫中某個對象的創(chuàng)建腳本
三、?分隔字符串
四、?一條語句執(zhí)行跨越若干個數(shù)據(jù)庫
五、?怎樣獲取一個表中所有的字段信息
六、?時間格式轉(zhuǎn)換問題
七、?分區(qū)視圖
八、?樹型的實(shí)現(xiàn)
九、?排序問題
十、?一條語句刪除一批記錄
十一、獲取子表內(nèi)的一列數(shù)據(jù)的組合字符串

?

?


一、?只復(fù)制一個表結(jié)構(gòu),不復(fù)制數(shù)據(jù)

?

?

[quote]?selec?top?0?*?into?[t1]?from?[t2][/quote]

?

?

三、?分隔字符串
如果有一個用逗號分割開的字符串,比如說"a,b,c,d,1,2,3,4",如何用t-sql獲取這個字符串有幾個元素,獲取第幾個元素的值是多少呢?因?yàn)閠-sql里沒有split函數(shù),也沒有數(shù)組的概念,所以只能自己寫幾個函數(shù)了。
1、?獲取元素個數(shù)的函數(shù)

?

?

create?function?getstrarrlength?(@str?varchar(8000))
returns?int
as
begin
??declare?@int_return?int
??declare?@start?int
??declare?@next?int
??declare?@location?int
??selec?@str?=','+?@str?+','
??selec?@str=replace(@str,',,',',')
??selec?@start?=1
??selec?@next?=1?
??selec?@location?=?charindex(',',@str,@start)
??while?(@location?<>0)
??begin
????selec?@start?=?@location?+1
????selec?@location?=?charindex(',',@str,@start)
????selec?@next?=@next?+1
??end
?selec?@int_return?=?@next-2
?return?@int_return
end

?

?

六、?時間格式轉(zhuǎn)換問題
因?yàn)樾麻_發(fā)的軟件需要用一些舊軟件生成的一些數(shù)據(jù),在時間格式上不統(tǒng)一,只能手工轉(zhuǎn)換,研究了一下午寫了三條語句,以前沒怎么用過convert函數(shù)和case語句,還有"+"操作符在不同上下文環(huán)境也會起到不同的作用,把我搞暈了要,不過現(xiàn)在看來是差不多弄好了。

?

?

1、把所有"70.07.06"這樣的值變成"1970-07-06"

?

?

UPDATE?lvshi
SET?shengri?=?'19'?+?REPLACE(shengri,?'.',?'-')
WHERE?(zhiyezheng?=?'139770070153')

?

?

?

2、在"1970-07-06"里提取"70","07","06"

?

?

selec?SUBSTRING(shengri,?3,?2)?AS?year,?SUBSTRING(shengri,?6,?2)?AS?month,?
??????SUBSTRING(shengri,?9,?2)?AS?day
FROM?lvshi
WHERE?(zhiyezheng?=?'139770070153')

?

?

3、把一個時間類型字段轉(zhuǎn)換成"1970-07-06"

?

?

UPDATE?lvshi
SET?shenling?=?CONVERT(varchar(4),?YEAR(shenling))?
??????+?'-'?+?CASE?WHEN?LEN(MONTH(shenling))?=?1?THEN?'0'?+?CONVERT(varchar(2),?
??????month(shenling))?ELSE?CONVERT(varchar(2),?month(shenling))?
??????END?+?'-'?+?CASE?WHEN?LEN(day(shenling))?=?1?THEN?'0'?+?CONVERT(char(2),?
??????day(shenling))?ELSE?CONVERT(varchar(2),?day(shenling))?END
WHERE?(zhiyezheng?=?'139770070153')

?

?

http://dev.csdn.net/develop/article/83/83138.shtm

轉(zhuǎn)載于:https://www.cnblogs.com/kittow/archive/2006/04/21/380889.html

總結(jié)

以上是生活随笔為你收集整理的[收藏]整理了一些T-SQL技巧的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。