你真的会玩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)+'')
季度的最后一天(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的值恢复到原是值。
其它干货下载资源已放入微信公众号【一个码农的日常】
你真的会玩SQL吗?实用函数方法汇总的更多相关文章
- 你真的会玩SQL吗?表表达式,排名函数
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?之逻辑查询处理阶段
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?和平大使 内连接、外连接
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?三范式、数据完整性
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?让人晕头转向的三值逻辑
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?EXISTS和IN之间的区别
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?无处不在的子查询
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?Case也疯狂
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
- 你真的会玩SQL吗?简单的数据修改
你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...
随机推荐
- 一步步开发自己的博客 .NET版(11、Web.config文件的读取和修改)
Web.config的读取 对于Web.config的读取大家都很属性了.平时我们用得比较多的就是appSettings节点下配置.如: 我们对应的代码是: = ConfigurationManage ...
- 实例操作JSONP原理
絮语:按这个步骤走,你就会明白JSONP是什么鬼. 1.工程目录: ng-mywork demo.html test.js 2.nginx的server配置 server { listen ; ser ...
- javascript之Object.defineProperty的奥妙
直切主题 今天遇到一个这样的功能: 写一个函数,该函数传递两个参数,第一个参数为返回对象的总数据量,第二个参数为初始化对象的数据.如: var o = obj (4, {name: 'xu', age ...
- UE4新手引导入门教程
请大家去这个地址下载:file:///D:/UE4%20Doc/虚幻4新手引导入门教程.pdf
- 前端制作动画的几种方式(css3,js)
制作动态的网页是是前端工程师必备的技能,很好的实现动画能够极大的提高用户体验,增强交互效果,那么动画有多少实现方式,一直对此有选择恐惧症的我就总结一下,以便在开发的时候选择最好的实现方式. 1.css ...
- 现代3D图形编程学习-基础简介(3)-什么是opengl (译)
本书系列 现代3D图形编程学习 OpenGL是什么 在我们编写openGL程序之前,我们首先需要知道什么是OpenGL. 将OpenGL作为一个API OpenGL 通常被认为是应用程序接口(API) ...
- C# salt+hash 加密
一.先明确几个基本概念 1.伪随机数:pseudo-random number generators ,简称为:PRNGs,是计算机利用一定的算法来产生的.伪随机数并不是假随机 数,这里的" ...
- 安装angular-cli
最近在学习angular2,并尝试用这个框架来做公司的一个新项目. 终于要开始开发了,等了1个多月. 因为第一次用这个新框架做项目,不太熟悉,就找了angular-cli这个脚手架来搭建项目. 安装了 ...
- Postman - 功能强大的 API 接口请求调试和管理工具
Postman 是一款功能强大的的 Chrome 应用,可以便捷的调试接口.前端开发人员在开发或者调试 Web 程序的时候是需要一些方法来跟踪网页请求的,用户可以使用一些网络的监视工具比如著名的 Fi ...
- arcgis api for js入门开发系列四地图查询(含源代码)
备注:由于实现本篇功能的需求,修改了地图数据的dlsearch.mxd,然后更新了地图服务,需要的在文章最后有提供最新的mxd以及源代码下载的 上一篇实现了demo的地图工具栏,本篇新增地图查询功能, ...