SQL Server 扩展一个支持类似。net 时间格式化的标量函数~
IF EXISTS(SELECT TOP 1 * FROM sys.objects WHERE name=N'uF_DateFormat' AND [type]='FN')
DROP FUNCTION uF_DateFormat
GO SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: hehai
-- Create date: 2015-11-27 16:06:43
-- Description: 对指定的时间进行指定格式的转换 /*
@formatString
年 份:yy / yyyy (15/2015)
月 份: mm/MM (1/01 11/11)
日 期:d/dd/D/DD (1/01 10/10)
小 时:h/hh/H/HH (6AM/06AM/6/06) h表示按照12时制格式化, H表示按照24时制格式化,若为h/hh时间最后有[AM 或 PM]
(6PM/06PM/18/18)
-------------------------------------------
分 钟:mi/mz (10/10 1/01)
秒 钟:si/ss (1/01 10/10)
秒 钟:mss/ms (0/10/999 000/010/999)
*/
-- =============================================
CREATE FUNCTION uF_DateFormat
(
@date DATETIME, -- 指定转换时间
@formatString NVARCHAR(30), -- 指定需要转换格式
@defaultIfdateIsNull NVARCHAR(30) -- 返回指定时间的指定转换格式结果字符
)
RETURNS NVARCHAR(30)
AS
BEGIN
DECLARE @R NVARCHAR(30),@T NVARCHAR(5),@C CHAR(2)=N'AM'
DECLARE @Y INT,@M TINYINT,@D TINYINT,@H TINYINT,@MI TINYINT,@SS TINYINT,@MS INT SET @Y=DATEPART([YEAR],@date)
SET @M=DATEPART([MONTH],@date)
SET @D=DATEPART([DAY],@date)
SET @H=DATEPART([HOUR],@date)
SET @MI=DATEPART([MINUTE],@date)
SET @SS=DATEPART([SECOND],@date)
SET @MS=DATEPART([MILLISECOND],@date) SET @R=@formatString SET @R=REPLACE(@R,N'yyyy',CAST(@Y AS NVARCHAR(4)))
SET @R=REPLACE(@R,N'YYYY',CAST(@Y AS NVARCHAR(4)))
SET @R=REPLACE(@R,N'yy',RIGHT( CAST(@Y AS NVARCHAR(4)),2))
SET @R=REPLACE(@R,N'YY',RIGHT( CAST(@Y AS NVARCHAR(4)),2)) SET @T=CAST(@M AS NVARCHAR(2))
IF @M<10 SET @T=N''+CAST(@M AS NVARCHAR(2))
SET @R=REPLACE(@R,N'MM',@T)
SET @R=REPLACE(@R,N'mm',@T) SET @T=CAST(@D AS NVARCHAR(2))
IF @D<10 SET @T=N''+CAST(@D AS NVARCHAR(2))
SET @R=REPLACE(@R,N'dd',@T)
SET @R=REPLACE(@R,N'DD',@T)
SET @R=REPLACE(@R,N'dd',@T)
SET @R=REPLACE(@R,N'd',@T) SET @T=CAST(@H AS NVARCHAR(2))
IF @H<10 SET @T=N''+CAST(@H AS NVARCHAR(2))
SET @R=REPLACE(@R,N'HH',@T)
SET @R=REPLACE(@R,N'H',@T) -- 12小时制 --
SET @T=CAST(@H AS NVARCHAR(2))
IF @H>=12
BEGIN
SET @C='PM'
SET @H=24-12
SET @T=CAST(@H AS NVARCHAR(2))
END
SET @R=REPLACE(@R,N'hh',@T)
SET @R=REPLACE(@R,N'h',@T) SET @T=CAST(@MI AS NVARCHAR(2))
IF @MI<10 SET @T=N''+CAST(@MI AS NVARCHAR(2))
SET @R=REPLACE(@R,N'mi',@T) SET @T=CAST(@SS AS NVARCHAR(2))
IF @SS<10 SET @T=N''+CAST(@SS AS NVARCHAR(2))
SET @R=REPLACE(@R,N'ss',@T)
SET @R=REPLACE(@R,N'si',@T) SET @T=CAST(@MS AS NVARCHAR(3))
IF @MS>=0 AND @MS<10 SET @T=N''+CAST(@MS AS NVARCHAR(1))
IF @MS>=10 AND @MS<100 SET @T=N''+CAST(@MS AS NVARCHAR(2))
SET @R=REPLACE(@R,N'ms',@T)
SET @R=REPLACE(@R,N'mss',@T) RETURN @R
END
GO -- 年月日
SELECT dbo.uF_DateFormat(getdate(),'yyyyMMdd',NULL)
SELECT dbo.uF_DateFormat(getdate(),'yyyy/MM/dd',NULL)
SELECT dbo.uF_DateFormat(getdate(),'yyyy-MM-dd',NULL)
SELECT dbo.uF_DateFormat(getdate(),'yyyy年MM月dd日',NULL) -- 年月日时分秒
SELECT dbo.uF_DateFormat(getdate(),'yyyyMMdd HH:mi:ss',NULL) -- 年月日时分秒 毫秒
SELECT dbo.uF_DateFormat(getdate(),'yyyy-MM-dd HH:mi:ss.ms',NULL)
SQL Server 扩展一个支持类似。net 时间格式化的标量函数~的更多相关文章
- Sql Server 中一个非常强大的日期格式化函数
Sql Server 中一个非常强大的日期格式化函数Select CONVERT(varchar(100), GETDATE(), 0)-- 05 16 2006 10:57AMSelect CONV ...
- SQL Server分区表,能否按照多个列作为分区函数的分区依据(转载)
问: Hi, I have a table workcachedetail with 40 million rows which has 8 columns.We decided to partiti ...
- SQL Server 扩展事件(Extented Events)从入门到进阶(1)——从SQL Trace到Extented Events
由于工作需要,决定深入研究SQL Server的扩展事件(Extended Events/xEvents),经过资料搜索,发现国外大牛的系列文章,作为“学习”阶段,我先翻译这系列文章,后续在工作中的心 ...
- SQL Server 扩展事件(Extented Events)从入门到进阶(4)——扩展事件引擎——基本概念
本文属于 SQL Server 扩展事件(Extented Events)从入门到进阶 系列 在第一二节中,我们创建了一些简单的.类似典型SQL Trace的扩展事件会话.在此过程中,介绍了很多扩展事 ...
- SQL Server 扩展事件(Extented Events)从入门到进阶(3)——通过界面操作Extented Event
本文属于 SQL Server扩展事件(Extended Events)从入门到进阶 系列 对于接纳扩展事件,其中一个最大的障碍就是要对XML和XQuery有一定的了解以便分析数据.我们可以使用T-S ...
- SQL Server 扩展事件
SQL Server 扩展事件(Extended Event)是用于服务器的常规事件处理系统,是追踪SQL Server系统运行状态的神器,同时也是一个日志记录工具,扩展事件完全可以取代SQL追踪(S ...
- SQL Server 扩展事件(Extented Events)从入门到进阶(2)——在GUI中创建基础扩展事件
本文属于 SQL Server 扩展事件(Extented Events)从入门到进阶 系列 第一篇文章中提到了如何在Profiler中创建跟踪(trace),并以服务器端(server-side)跟 ...
- SQL Server 2012:SQL Server体系结构——一个查询的生命周期(第1部分)
为了缩小读取操作所涉及范围,本文首先着眼于简单的SELECT查询,然后引入执行更新操作有关的附加过程.最后你会读到,优化性能时SQLServer使用还原工具的相关术语和流程. 关系和存储引擎 如图所示 ...
- SQL Server 2012:SQL Server体系结构——一个查询的生命周期(第3部分)(完结)
一个简单的更新查询 现在应该知道只读取数据的查询生命周期,下一步来认定当你需要更新数据时会发生什么.这个部分通过看一个简单的UPDATE查询,修改刚才例子里读取的数据,来回答. 庆幸的是,直到存取方法 ...
随机推荐
- [solr] - 环境搭建2
前面使用Tomcat搭建solr,参考文章: http://www.cnblogs.com/HD/p/3977799.html 原来solr可以不使用tomcat/jboss等服务器,它自身已经集成了 ...
- NodeJs http.get 方法请求时间过长问题处理!
NodeJs 获取网页内容 http.get 默认请求超时过长了,程序要卡死好一会. 根据网上资料现改造了一个带超时设置的获取网页内容方法. 主要方法使用 setTimeout 来超时, 代码如下: ...
- ios实现屏幕旋转的方法
1.屏蔽AppDelegate下面的屏幕旋转方法 #pragma mark - 屏幕旋转的 //- (UIInterfaceOrientationMask)application:(UIApplica ...
- 【mysql】压缩myisam数据表
myisam引擎介绍 存储结构: MyISAM每张表被存放在三个文件: frm:表格定义: MYD(MYData):数据文件: MYI(MYIndex):索引文件: 存储空间: MyISAM可被压 ...
- CSS组件架构的设计思想
不管是设计思想,还是架构,都可以总结为一个词:AO模式.A表示Append,即“附加”的意思,O表示Overwrite,即“重写”的意思.所有的CSS组件都是沿用这种思想来设计的.这也是CSS的特性, ...
- webpy分页类 + 上传类
webpy没有分页类.按照php的思路.自己编了一个.数据库用的是sqlite. class Page(object): '''分页类''' def __init__(self,page_size,d ...
- Vs打包工程 错误: Unable to update the dependencies of the project (转)
Setup Project 错误: Unable to update the dependencies of the project 在VS2010中编译包含安装工程的解决方案提示错误:Unable ...
- Java内各种进制的表示
不同进制的数据表现: 二进制:由0,1组成.以0b开头. 八进制:由0,1,...7组成.以0开头. 十进制:由0,1,...9组成.默认整数是十进制. 十六进制:由0,1,...9,a,b,c,d, ...
- 搭建nexus后,进入首页的时候出现warning: Could not connect to Nexus.错误
nexus出现这种问题,一般是版本太旧,换一个高版本的nexus就能解决了.
- solr 5.5.1安装并配置中文分词IKAnalyzer
http://www.360doc.com/content/16/0623/17/5131531_570184594.shtml ——————————————————————————————————— ...