實用函式方法
由於有些知識很少被用到,但真需要用時卻忘記了又焦頭爛額的到處找。
現在將這些‘冷門“卻有效的小知識貢獻出來,以備不時之需。
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的值恢復到原是值。 |