SQL Server常用函数汇总
1.day(date)
用途:获取日期是所在月的几号
参数:date是一个可以解析为 time、date、smalldatetime、datetime、datetime2 或 datetimeoffset 值的表达式、列表达式、用户定义的变量或字符串文字
返回值:一个整数,该整数表示指定的 date 是该月份的哪一天
eg:
day(getdate()) --获取当前时间是当前月份的哪一天
扩展:
select CONVERT(VARCHAR(10),DATEADD(dd,-day(getdate())+1,getdate()),120) --获取当月的开始日期
select CONVERT(VARCHAR(10),dateadd(dd,-day(getdate()),dateadd(m,1,getdate())),120) --获取当月的结束日期
2.DATEFIRST
用途:设置一周是以星期几开始
语法:SET DATEFIRST {Num}
参数:num是一个数值, 指示一周的第一天的一个整数。 可以是下列值之一。
-
值
一周的第一天是
1
星期一
2
星期二
3
星期三
4
星期四
5
星期五
6
星期六
7 (默认值,美国英语)
星期日
eg:
SET DATEFIRST 1
注释:
(1)若要查看 SET DATEFIRST 的当前设置,请使用 @@DATEFIRST 函数。
eg:
SELECT @@DATEFIRST
(2)SET DATEFIRST 的设置是在执行或运行时设置,而不是在分析时设置。
(3)指定 SET DATEFIRST 对 DATEDIFF 不起作用。 DATEDIFF 始终使用星期日作为每周的第一天,以确保函数是确定性的。
3.DATEPART()
用途: DATEPART() 函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等
语法:DATEPART(datepart,date)
参数:date 参数是合法的日期表达式。datepart 参数可以是下列的值:
| datepart | 缩写 |
|---|---|
| 年 | yy, yyyy |
| 季度 | qq, q |
| 月 | mm, m |
| 年中的日 | dy, y |
| 日 | dd, d |
| 周 | wk, ww |
| 星期 | dw, w |
| 小时 | hh |
| 分钟 | mi, n |
| 秒 | ss, s |
| 毫秒 | ms |
| 微妙 | mcs |
| 纳秒 | ns |
eg:
SET DATEFIRST 1 --设置一周的开始为星期一
select datepart(w,getdate())
扩展:
SET DATEFIRST 1 --设置一周的开始为星期一
select CONVERT(VARCHAR(10),getdate()-datepart(w,getdate())+1,120) --当前日前所在周的开始日期
select CONVERT(VARCHAR(10),getdate()-datepart(w,getdate())+7 ,120) --当前日前所在周的结束日期
4.SQL中的两种数据转换方式
语法:CAST ( expression AS data_type [ ( length ) ] )
CONVERT ( data_type [ ( length ) ] , expression [ , style ] ) 参数:expression:任何有效的表达式。
data_type :目标数据类型。 这包括 xml、bigint 和 sql_variant。 不能使用别名数据类型。
length:指定目标数据类型长度的可选整数。 默认值为 30。
style:指定 CONVERT 函数如何转换 expression 的整数表达式。 如果 style为 NULL,则返回 NULL。 该范围是由 data_type 确定的。
返回值:转换为 data_type 的 expression。
注释:convert中data_type为日期时间类型时,style的集中类型如下表
|
不带世纪数位 (yy) (1) |
带世纪数位 (yyyy) |
标准 |
输入/输出 (3) |
||
|---|---|---|---|---|---|
|
- |
0 或100(1、2) |
默认 |
mon dd yyyy hh:miAM(或 PM) |
||
|
1 |
101 |
美国 |
1 = mm/dd/yy 101 = mm/dd/yyyy |
||
|
2 |
102 |
ANSI |
2 = yy.mm.dd 102 = yyyy.mm.dd |
||
|
3 |
103 |
英国/法国 |
3 = dd/mm/yy 103 = dd/mm/yyyy |
||
|
4 |
104 |
德国 |
4 = dd.mm.yy 104 = dd.mm.yyyy |
||
|
5 |
105 |
意大利 |
5 = dd-mm-yy 105 = dd-mm-yyyy |
||
|
6 |
106 (1) |
- |
6 = dd mon yy 106 = dd mon yyyy |
||
|
7 |
107 (1) |
- |
7 = Mon dd, yy 107 = Mon dd, yyyy |
||
|
8 |
108 |
- |
hh:mi:ss |
||
|
- |
9 或109(1、2) |
默认格式 + 毫秒 |
mon dd yyyy hh:mi:ss:mmmAM(或 PM) |
||
|
10 |
110 |
美国 |
10 = mm-dd-yy 110 = mm-dd-yyyy |
||
|
11 |
111 |
日本 |
11 = yy/mm/dd 111 = yyyy/mm/dd |
||
|
12 |
112 |
ISO |
12 = yymmdd 112 = yyyymmdd |
||
|
- |
13 或113(1、2) |
欧洲默认格式 + 毫秒 |
dd mon yyyy hh:mi:ss:mmm(24h) |
||
|
14 |
114 |
- |
hh:mi:ss:mmm(24h) |
||
|
- |
20 或 120 (2) |
ODBC 规范 |
yyyy-mm-dd hh:mi:ss(24h) |
||
|
- |
21 或 121 (2) |
ODBC 规范(带毫秒) |
yyyy-mm-dd hh:mi:ss.mmm(24h) |
||
|
- |
126 (4) |
ISO8601 |
yyyy-mm-ddThh:mi:ss.mmm(无空格)
|
||
|
- |
127(6, 7) |
带时区 Z 的 ISO8601。 |
yyyy-mm-ddThh:mi:ss.mmmZ(无空格)
|
||
|
- |
130 (1,2) |
回历 (5) |
dd mon yyyy hh:mi:ss:mmmAM 在此样式中,mon 表示完整月份名称的多标记回历 unicode 表示形式。 该值在 SSMS 的默认 US 安装中将不会正确呈现。 |
||
|
- |
131 (2) |
回历 (5) |
dd/mm/yyyy hh:mi:ss:mmmAM |
eg:
SELECT
GETDATE() AS UnconvertedDateTime,
CAST(GETDATE() AS nvarchar()) AS UsingCast,
CONVERT(nvarchar(), GETDATE(), ) AS 'ODBC 规范' ,
CONVERT(nvarchar(), GETDATE(), ) AS 'ODBC 规范(带毫秒' ;
GO
5.DATEDIFF()
语法:DATEDIFF(datepart,startdate,enddate)
参数:startdate 和 enddate 参数是合法的日期表达式。
注释:datepart 参数可以是下列的值:
| datepart | 缩写 |
|---|---|
| 年 | yy, yyyy |
| 季度 | qq, q |
| 月 | mm, m |
| 年中的日 | dy, y |
| 日 | dd, d |
| 周 | wk, ww |
| 星期 | dw, w |
| 小时 | hh |
| 分钟 | mi, n |
| 秒 | ss, s |
| 毫秒 | ms |
| 微妙 | mcs |
| 纳秒 | ns |
SQL Server常用函数汇总的更多相关文章
- SQL Server 常用函数使用方法
之前就想要把一些 SQL 的常用函数记录下来, 直到今天用到substring()这个函数,C# 里面这个方法起始值是 0,而 SQL 里面起始值是 1.傻傻分不清楚... 这篇博客作为记录 SQL ...
- Oracle 与Sql Server常用函数对比
来自:http://topic.csdn.net/u/20080704/08/b2b8c42f-b0d6-4cda-98b1-6e4a279b4ff8.html 感谢楼主 函数 SQLServer和O ...
- SQL Server 常用函数总结
SQL去空格函数 1.ltrim(‘内容’)--去掉字符左边的空格 代码如下 declare @str varchar(100) set @str=' ADFADF' select @str sele ...
- SQL Server 常用函数使用方法(持续更新)
之前就想要把一些 SQL 的常用函数记录下来,不过一直没有实行...嘿嘿... 直到今天用到substring()这个函数,C# 里面这个方法起始值是 0,而 SQL 里面起始值是 1.傻傻分不清楚. ...
- sql server常用函数、常用语句
一.常用函数 1.字符串函数 : charindex(':','abc:123') --寻找一个字符在一段字符串中起始的位置 len('zhangsan') --获取一段字符串的长度 lef ...
- Sql Server常用函数及技巧
使用Sql Server好长时间了,今天特别想总结一下,算是回顾吧! 总结: 其实很多技巧,都是基于SQL Server自带的System Views,System Stored Procedures ...
- SQL Server 常用函数
1.DATEADD 在向指定日期加上一段时间的基础上,返回新的 datetime 值. 语法 DATEADD ( datepart , number, date ) 参数 datepart 是规定应向 ...
- SQL SERVER常用语法汇总
阅读目录 一.SQL分类 二.基础语句 三.sql技巧 四.(MS SQL Server)SQL语句导入导出大全 回到目录 一.SQL分类 DDL—数据定义语言(CREATE,ALTER,DROP,D ...
- SQL Server常用函数使用方法(学习)
1.转载至 https://www.cnblogs.com/Brambling/p/6779434.html Substring()函数,用于截取字符串方法,三个参数 参数1:用于指定要操作的字符串 ...
随机推荐
- AAAA block
[self AAAA:^(BOOL isSuccessed, id userInfo, NSString *errorMsg) { NSLog(@"AAAA: %d, userInfo: % ...
- android 中的 Handler 线程间通信
一. 在MainActivity中为什么只是类似的写一行如下代码就可以使用handler了呢? Handler handler = new Handler() { @Override public v ...
- AngularJS体验式编程系列文章
AngularJS体验式编程系列文章,将介绍如何用angularjs构建一个强大的web前端系统.angularjs是由Google团队开发的一款非常优秀web前端框架.在当前如此多的web框架下,a ...
- 记一次netty版本冲突,报java.lang.NoSuchMethodError: io.netty.util.internal.ObjectUtil.checkPositive的问题
elasticsearch 5.6中使用TransportClient初始化抛异常 在引入elasticsearch5.6的transportclient包中,会引入netty进行通信. <!- ...
- Ubuntu 的 apt-get 代理设置(zhuan)
url: http://qixinglu.com/post/ubuntu_apt-get_proxy_setup.html 升级到 Ubuntu10.04 后,发现 apt-get 的代理设置有改变了 ...
- CentOS上扩充lv-root空间步骤详解
查看服务器发现vg_host01-lv_root下的空间占用的比较多,需要扩容. 有以下两种方案: )利用空余的磁盘,扩展lv_root的大小(推荐) )将lv_home的空间挪出一部分给lv_roo ...
- poj 1182 食物链 并查集的又一个用法
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 41584 Accepted: 12090 Descripti ...
- [python小记]使用lxml修改xml文件,并遍历目录
这次的目的是遍历目录,把目标文件及相应的目录信息更新到xml文件中.在经过痛苦的摸索之后,从python自带的ElementTree投奔向了lxml.而弃用自带的ElementTree的原因就是,na ...
- 当一个线程进入一个对象的synchronized方法A之后,其他线程是否可进入此对象的synchronized方法B?
给出答案: 是不能的,其他线程只能访问该对象的非同步方法,同步方法则不能进入; 因为非静态方法上的synchronized修饰符要求执行方法时要获得对象的锁,如果已经进入A方法,说明对象锁已经被取
- Oracle之比较NVARCHAR2字符串
一.引言 昨天遇到一个问题,一直想不通是为什么,我在pl/sql里面执行sql语句,选出字段值等于某个值的的行: '; 用select * from test;是可以查到该值的,但是用这条语句却没有结 ...
注意