当前位置: 首页 > news >正文

你真的会玩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)

相关文章:

  • Lingo中命令脚本文件使用范例
  • c++ 复数类
  • 软件项目发展历史人月神话这本书好
  • Linux -- ubuntu下安装程序的三种方法
  • iOS 利用UIWebView与JavaScript交互的最简单办法(本人已验证可行)
  • 2015-10-14 晴 tcp/ip
  • 00.Python manage.py shell和 Python的分析
  • Visifire实现统计图
  • SecureCRT系列:生成公私钥
  • 技巧之:恢复linux被误删文件(方案有3)
  • 非法词判断
  • 教你爱上Blocks(闭包)
  • 【python游戏编程之旅】第四篇---pygame中加载位图与常用的数学函数。
  • 导出excel
  • Oracle坑爹入门踩坑篇
  • [ JavaScript ] 数据结构与算法 —— 链表
  • 2019年如何成为全栈工程师?
  • C++入门教程(10):for 语句
  • download使用浅析
  • JavaWeb(学习笔记二)
  • Java编程基础24——递归练习
  • Puppeteer:浏览器控制器
  • Spark学习笔记之相关记录
  • springMvc学习笔记(2)
  • use Google search engine
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 从零开始的webpack生活-0x009:FilesLoader装载文件
  • 如何进阶一名有竞争力的程序员?
  • 事件委托的小应用
  • 吐槽Javascript系列二:数组中的splice和slice方法
  • 微信小程序设置上一页数据
  • 【运维趟坑回忆录】vpc迁移 - 吃螃蟹之路
  • 好程序员大数据教程Hadoop全分布安装(非HA)
  • ​ ​Redis(五)主从复制:主从模式介绍、配置、拓扑(一主一从结构、一主多从结构、树形主从结构)、原理(复制过程、​​​​​​​数据同步psync)、总结
  • ​iOS安全加固方法及实现
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • ​什么是bug?bug的源头在哪里?
  • #define
  • #pragma预处理命令
  • #经典论文 异质山坡的物理模型 2 有效导水率
  • #使用清华镜像源 安装/更新 指定版本tensorflow
  • #我与Java虚拟机的故事#连载03:面试过的百度,滴滴,快手都问了这些问题
  • $ git push -u origin master 推送到远程库出错
  • (04)Hive的相关概念——order by 、sort by、distribute by 、cluster by
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (附源码)springboot家庭装修管理系统 毕业设计 613205
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (学习日记)2024.01.19
  • (转)GCC在C语言中内嵌汇编 asm __volatile__
  • (转)Linux下编译安装log4cxx
  • ****** 二 ******、软设笔记【数据结构】-KMP算法、树、二叉树
  • ./include/caffe/util/cudnn.hpp: In function ‘const char* cudnnGetErrorString(cudnnStatus_t)’: ./incl
  • .[hudsonL@cock.li].mkp勒索病毒数据怎么处理|数据解密恢复
  • .mysql secret在哪_MYSQL基本操作(上)