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 时间格式化的标量函数~的更多相关文章

  1. Sql Server 中一个非常强大的日期格式化函数

    Sql Server 中一个非常强大的日期格式化函数Select CONVERT(varchar(100), GETDATE(), 0)-- 05 16 2006 10:57AMSelect CONV ...

  2. SQL Server分区表,能否按照多个列作为分区函数的分区依据(转载)

    问: Hi, I have a table workcachedetail with 40 million rows which has 8 columns.We decided to partiti ...

  3. SQL Server 扩展事件(Extented Events)从入门到进阶(1)——从SQL Trace到Extented Events

    由于工作需要,决定深入研究SQL Server的扩展事件(Extended Events/xEvents),经过资料搜索,发现国外大牛的系列文章,作为“学习”阶段,我先翻译这系列文章,后续在工作中的心 ...

  4. SQL Server 扩展事件(Extented Events)从入门到进阶(4)——扩展事件引擎——基本概念

    本文属于 SQL Server 扩展事件(Extented Events)从入门到进阶 系列 在第一二节中,我们创建了一些简单的.类似典型SQL Trace的扩展事件会话.在此过程中,介绍了很多扩展事 ...

  5. SQL Server 扩展事件(Extented Events)从入门到进阶(3)——通过界面操作Extented Event

    本文属于 SQL Server扩展事件(Extended Events)从入门到进阶 系列 对于接纳扩展事件,其中一个最大的障碍就是要对XML和XQuery有一定的了解以便分析数据.我们可以使用T-S ...

  6. SQL Server 扩展事件

    SQL Server 扩展事件(Extended Event)是用于服务器的常规事件处理系统,是追踪SQL Server系统运行状态的神器,同时也是一个日志记录工具,扩展事件完全可以取代SQL追踪(S ...

  7. SQL Server 扩展事件(Extented Events)从入门到进阶(2)——在GUI中创建基础扩展事件

    本文属于 SQL Server 扩展事件(Extented Events)从入门到进阶 系列 第一篇文章中提到了如何在Profiler中创建跟踪(trace),并以服务器端(server-side)跟 ...

  8. SQL Server 2012:SQL Server体系结构——一个查询的生命周期(第1部分)

    为了缩小读取操作所涉及范围,本文首先着眼于简单的SELECT查询,然后引入执行更新操作有关的附加过程.最后你会读到,优化性能时SQLServer使用还原工具的相关术语和流程. 关系和存储引擎 如图所示 ...

  9. SQL Server 2012:SQL Server体系结构——一个查询的生命周期(第3部分)(完结)

    一个简单的更新查询 现在应该知道只读取数据的查询生命周期,下一步来认定当你需要更新数据时会发生什么.这个部分通过看一个简单的UPDATE查询,修改刚才例子里读取的数据,来回答. 庆幸的是,直到存取方法 ...

随机推荐

  1. [zz] demand ,require ,request用法辨析

    http://zhidao.baidu.com/link?url=9Q50HiOF1fWav1nSnREbc_H1jTuAHxAjeVLbZoB5bGO3ZehPxLhQdob4oGO3slMRl0W ...

  2. LVS-DR工作原理图文详解

    为了阐述方便,我根据官方原理图另外制作了一幅图,如下图所示:VS/DR的体系结构: 我将结合这幅原理图及具体的实例来讲解一下LVS-DR的原理,包括数据包.数据帧的走向和转换过程. 官方的原理说明:D ...

  3. X5的UI部分和传统Web页面开发的差异

    http://doc.wex5.com/different-with-std-web-ui/#1 X5的UI部分和传统Web页面开发的差异 WeX5是跨端移动开发框架,BeX5是基于WeX5的企业快速 ...

  4. Apache + PHP 环境搭建

    环境: Win7 64位 php-5.6.19-Win32-VC11-x64 httpd-2.4.18-win64-VC11 下载地址: php:  http://windows.php.net/do ...

  5. bootstrap-轮播图

    <!-- 1.写一个父级,class为carousel slide:添加滑动的效果 data-interval 图片轮播间隔时间,单位ms data-ride="carousel&qu ...

  6. Python基础篇【第1篇】: Python基础

    Python 简介 Python 是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言. Python 的设计具有很强的可读性,相比其他语言经常使用英文关键字,其他语言的一些标点符号,它具有 ...

  7. 【摘】使用tail、head命令过滤行

    tail  -n  10  test.log   查询日志尾部最后10行的日志; tail -n +10 test.log    查询10行之后的所有日志; head -n 10  test.log  ...

  8. 'libxml/tree.h' file not found

    看看Header Search Paths 为  '/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Dev ...

  9. TortoiseSVN 版本回滚

    尝试用TortoiseSVN进行版本回滚,回滚到的版本和实际的内容有出入,可能是点了太多次给点乱了,囧~ 不过发现一个比较靠谱的方法,如下: 右键点击文件TortoiseSVN->showlog ...

  10. 【T电商2】ftp服务器搭建

    一.为什么需要ftp? 分布式环境一般都有一个专门的图片服务器存放图片.我们使用虚拟机搭建一个专门的服务器来存放图片.在此服务器上安装一个nginx来提供http服务,安装一个ftp服务器来提供图片上 ...