你真的會玩SQL嗎箫津?實用函數(shù)方法匯總

作者:歡醉
原文地址:http://www.cnblogs.com/zhangs1986/p/4917800.html

實用函數(shù)方法

由于有些知識很少被用到,但真需要用時卻忘記了又焦頭爛額的到處找∪侣樱現(xiàn)在將這些‘冷門“卻有效的小知識貢獻出來酸些,以備不時之需。

存儲過程中的 '''' 相當(dāng)于數(shù)據(jù)庫中的‘ 單引號
DECLARE @str VARCHAR(100)
SET @str='''aaa'''
SELECT REPLACE(@str,'''','"')
:"aaa"
rtrim :使用 LTRIM 刪除字符變量中的前導(dǎo)空格 ; RTRIM 刪除字符變量中的尾隨空格
rtrim(ltrim(splitdata))
-- 用select into 把數(shù)據(jù)放到臨時表中琐谤,按交費期限排序蟆技,并加上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 創(chuàng)建臨時表 插入自增列
  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
            
            --調(diào)整計數(shù)器
            Set @Count = @Count + 1
        End
Return 執(zhí)行不成功,中斷執(zhí)行
If Exists(select 8 from cb_HsCost where ProjectCode = @ProjectCode and IsJianAn = 1)
   If @ProjectGUID Is Null
    Begin
        Print '[' + @ProjectCode + ']:當(dāng)前指定的項目在當(dāng)前系統(tǒng)中不存在斗忌!'
        Return -1
    End
得到包含前月在內(nèi)的一年時間
SET @dtBeginDate = getdate()
SET @dtEndDate = dateadd(month,-1,dateadd(year,1,@dtBeginDate))

高能預(yù)警

DATEPART ( datepart , date ) datepart函數(shù)中一周是周日到周六质礼,而我們通常認為一周是周一到周日
 返回表示指定日期的指定日期部分的整數(shù)
本周第一天 (星期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())  
本月最后一天(當(dāng)前為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)  
周內(nèi)的第幾日  
select datepart(weekday,getdate()) as 周內(nèi)的第幾日  
年內(nèi)的第幾周  
select datepart(week,getdate()) as 年內(nèi)的第幾周  
年內(nèi)的第幾季  
select datepart(quarter,getdate()) as 年內(nèi)的第幾季

快速高效創(chuàng)建數(shù)字輔助表

--創(chuàng)建數(shù)字輔助表
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 @max AS INT ,@rc AS INT ;
 SET @max=10000;
 SET @rc=1;
 
 INSERT INTO dbo.Nums VALUES (1);
 WHILE @rc * 2 <= @max
 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

練習(xí):將下面表1每行字符串轉(zhuǎn)化為表2格式

/*PlanDetailID  Description
   課程詳細安排1,課程詳細安排1.1,課程詳細安排1.2,課程詳細安排1.3
   課程詳細安排2,課程詳細安排2.1,課程詳細安排2.2
   課程詳細安排3,課程詳細安排3.1,課程詳細安排3.2,課程詳細安排3.3,課程詳細安排3.4
   課程詳細安排4
   課程詳細安排5

轉(zhuǎn)化為:
PlanDetailID pos Description
   1    課程詳細安排1
   2    課程詳細安排1.1
   3    課程詳細安排1.2
   4    課程詳細安排1.3
   1    課程詳細安排2
   2    課程詳細安排2.1
   3    課程詳細安排2.2
   1    課程詳細安排3
   2    課程詳細安排3.1
   3    課程詳細安排3.2
   4    課程詳細安排3.3
   5    課程詳細安排3.4
   1    課程詳細安排4
   1    課程詳細安排5
*/

參考SQL:

--生成副本,按逗號的個數(shù)飞蹂,n為逗號的位置(默認第一位為逗號)
SELECT  PlanDetailID ,
        Description ,
        n
FROM    dbo.T_PlanDetail
        INNER JOIN dbo.Nums ON n <= LEN(Description) + 1   --若無AND几苍,則表示按字符個數(shù)來生成行數(shù)
                               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,則表示按字符個數(shù)來生成行數(shù)
                               AND SUBSTRING(',' + Description, n, 1) = ',' ;--將含有逗號時候的行輸出
                               
--計算每個字符串在數(shù)組中的位置,按PlanDetailID 分區(qū)陈哑,按 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,則表示按字符個數(shù)來生成行數(shù)
                               AND SUBSTRING(',' + Description, n, 1) = ',' ;--將含有逗號時候的行輸出

在sql server中經(jīng)常有這樣的問題:一個表采用了自動編號的列之后伸眶,由于測試了好多數(shù)據(jù)惊窖,自動編號已累計了上萬個。現(xiàn)在正是要用這個表了厘贼,測試數(shù)據(jù)已經(jīng)刪了界酒,遺留下來的問題 就是在錄入新的數(shù)據(jù),編號只會繼續(xù)增加嘴秸,已使用過的但已刪除的編號就不能用了毁欣, 誰知道如何解決此問題庇谆?

truncate命令不但會清除所有的數(shù)據(jù),還會將IDENTITY的SEED的值恢復(fù)到原是值凭疮。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末饭耳,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子执解,更是在濱河造成了極大的恐慌寞肖,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件衰腌,死亡現(xiàn)場離奇詭異新蟆,居然都是意外死亡,警方通過查閱死者的電腦和手機右蕊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進店門琼稻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人饶囚,你說我怎么就攤上這事欣簇。” “怎么了坯约?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵熊咽,是天一觀的道長。 經(jīng)常有香客問我闹丐,道長横殴,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任卿拴,我火速辦了婚禮衫仑,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘堕花。我一直安慰自己文狱,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布缘挽。 她就那樣靜靜地躺著瞄崇,像睡著了一般。 火紅的嫁衣襯著肌膚如雪壕曼。 梳的紋絲不亂的頭發(fā)上苏研,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天,我揣著相機與錄音腮郊,去河邊找鬼摹蘑。 笑死,一個胖子當(dāng)著我的面吹牛轧飞,可吹牛的內(nèi)容都是我干的衅鹿。 我是一名探鬼主播撒踪,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼大渤!你這毒婦竟也來了制妄?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤兼犯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后切黔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體砸脊,經(jīng)...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年纬霞,在試婚紗的時候發(fā)現(xiàn)自己被綠了凌埂。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,814評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡诗芜,死狀恐怖瞳抓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情伏恐,我是刑警寧澤孩哑,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站翠桦,受9級特大地震影響横蜒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜销凑,卻給世界環(huán)境...
    茶點故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一丛晌、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧斗幼,春花似錦澎蛛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至渠羞,卻和暖如春斤贰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背次询。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瓷叫,地道東北人屯吊。 一個月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓送巡,卻偏偏與公主長得像,于是被迫代替她去往敵國和親盒卸。 傳聞我的和親對象是個殘疾皇子骗爆,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,728評論 2 351

推薦閱讀更多精彩內(nèi)容