你真的會玩SQL嗎?實用函數方法匯總


你真的會玩SQL嗎?系列目錄

你真的會玩SQL嗎?之邏輯查詢處理階段

你真的會玩SQL嗎?和平大使 內連接、外連接

你真的會玩SQL嗎?三范式、數據完整性

你真的會玩SQL嗎?查詢指定節點及其所有父節點的方法

你真的會玩SQL嗎?讓人暈頭轉向的三值邏輯

你真的會玩SQL嗎?EXISTS和IN之間的區別

你真的會玩SQL嗎?無處不在的子查詢

你真的會玩SQL嗎?Case也瘋狂

你真的會玩SQL嗎?表表達式,排名函數

你真的會玩SQL嗎?簡單的 數據修改

你真的會玩SQL嗎?你所不知道的 數據聚合

你真的會玩SQL嗎?透視轉換的藝術

你真的會玩SQL嗎?冷落的Top和Apply

你真的會玩SQL嗎?實用函數方法匯總

      你真的會玩SQL嗎?玩爆你的數據報表之存儲過程編寫(上)

    你真的會玩SQL嗎?玩爆你的數據報表之存儲過程編寫(下)

實用函數方法

由於有些知識很少被用到,但真需要用時卻忘記了又焦頭爛額的到處找。

現在將這些‘冷門“卻有效的小知識貢獻出來,以備不時之需。

 

存儲過程中的 '''' 相當於數據庫中的‘ 單引號
DECLARE @str VARCHAR(100)
SET @str='''aaa'''
SELECT REPLACE(@str,'''','"')
:"aaa"

 

rtrim :使用 LTRIM 刪除字符變量中的前導空格 ; RTRIM 刪除字符變量中的尾隨空格
rtrim(ltrim(splitdata))

 

-- 用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

 

用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 
Return 執行不成功,中斷執行
If Exists(select 8 from cb_HsCost where ProjectCode = @ProjectCode and IsJianAn = 1)
   If @ProjectGUID Is Null
    Begin
        Print '[' + @ProjectCode + ']:當前指定的項目在當前系統中不存在!'
        Return -1
    End
得到包含前月在內的一年時間
SET @dtBeginDate = getdate()
SET @dtEndDate = dateadd(month,-1,dateadd(year,1,@dtBeginDate))

高能預警

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 年內的第幾季  

 快速高效創建數字輔助表

--創建數字輔助表
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

   練習:將下面表1每行字符串轉化為表2格式

/*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:

--生成副本,按逗號的個數,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) = ',' ;--將含有逗號時候的行輸出 

 

在sql server中經常有這樣的問題:
一個表采用了自動編號的列之后,由於測試了好多數據,自動編號已累計了上萬個。
現在正是要用這個表了,測試數據已經刪了,遺留下來的問題 就是在錄入新的數據,編號只會繼續增加,已使用過的但已刪除的編號就不能用了,
 誰知道如何解決此問題?

truncate命令不但會清除所有的數據,還會將IDENTITY的SEED的值恢復到原是值。

   其它干貨下載資源已放入微信公眾號【一個碼農的日常】


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM