你真的会玩SQL吗?实用函数方法汇总

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

实用函数方法

由于有些知识很少被用到,但真需要用时却忘记了又焦头烂额的到处找。现在将这些‘冷门“却有效的小知识贡献出来,以备不时之需。

存储过程中的 '''' 相当于数据库中的‘ 单引号
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.2,课程详细安排1.3
   课程详细安排2,课程详细安排2.1,课程详细安排2.2
   课程详细安排3,课程详细安排3.1,课程详细安排3.2,课程详细安排3.3,课程详细安排3.4
   课程详细安排4
   课程详细安排5

转化为:
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:

--生成副本,按逗号的个数,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的值恢复到原是值。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容