sql server 查询日期中的常用语句, 例如本周第一天, 年内的第几周,有用
--本周第一天
SELECT
DATEADD(
Day
,1-(DATEPART(Weekday,getdate())+@@DATEFIRST-1)%7,getdate())
--or
select
dateadd(wk, datediff(wk,0,getdate()), 0)
--本周第一天
select
dateadd(wk, datediff(wk,0,getdate()), 6)
--上月第一天
SELECT
CONVERT
(
CHAR
(10),DATEADD(
month
,-1,DATEADD(dd,-
DAY
(GETDATE())+1,GETDATE())),111)
--上月最后一天
SELECT
CONVERT
(
CHAR
(10),DATEADD(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()),0)),111)+
' 23:59:59'
--本月第一天
select
dateadd(dd,-datepart(dd,getdate())+1,getdate())
--本月最后一天
select
dateadd(dd,-datepart(dd,getdate()) ,dateadd(mm,1,getdate()))
--本月天数
select
datediff(dd,dateadd(dd,-datepart(dd,getdate())+1,getdate()), dateadd(dd,-datepart(dd,getdate())+1,dateadd(mm,1,getdate())))
--or
select
datepart(dd,dateadd(dd,-1,dateadd(mm,1,
cast
(
cast
(
year
(getdate())
as
varchar
)+
'-'
+
cast
(
month
(getdate())
as
varchar
)+
'-01'
as
datetime))))
--下月第一天
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(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))
--今年第一天
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
年内的第几季
--判断某天是当月的第几周的sql函数
CREATE
FUNCTION
WeekOfMonth(@
day
datetime)
RETURNS
int
AS
begin
----declare @day datetime
declare
@num
int
declare
@Start datetime
declare
@dd
int
declare
@dayofweek
char
(8)
declare
@dayofweek_num
char
(8)
declare
@startWeekDays
int
---set @day='2009-07-05'
if datepart(dd,@
day
)=1
return
1
else
set
@Start= (
SELECT
DATEADD(mm, DATEDIFF(mm,0,@
day
), 0))
--一个月第一天的
set
@dayofweek= (datename(weekday,@Start))
---得到本月第一天是周几
set
@dayofweek_num=(
select
(
case
@dayofweek
when
'星期一'
then
2
when
'星期二'
then
3
when
'星期三'
then
4
when
'星期四'
then
5
when
'星期五'
then
6
when
'星期六'
then
7
when
'星期日'
then
1
end
))
set
@dayofweek_num= 7-@dayofweek_num+1
---得到本月的第一周一共有几天
---print @dayofweek_num
set
@dd=datepart(dd,@
day
)
----得到今天是这个月的第几天
--print @dd
if @dd<=@dayofweek_num
--小于前一周的天数
return
1
else
set
@dd=@dd-@dayofweek_num
if @dd % 7=0
begin
set
@num=@dd / 7
return
@num+1
end
else
--if @dd % 7<>0
set
@num=@dd / 7
set
@num=@num+1+1
return
@num
end
sql server 查询日期中的常用语句, 例如本周第一天, 年内的第几周,有用的更多相关文章
- SQL Server 查询、搜索命令、语句
--查询所有表 SELECT NAME,* FROM SYSOBJECTS WHERE XTYPE='U' order by SYSOBJECTS.name --查询所有存储过程 select * f ...
- SQL Server 查询处理中的各个阶段(SQL执行顺序)
SQL 不同于与其他编程语言的最明显特征是处理代码的顺序.在大数编程语言中,代码按编码顺序被处理,但是在SQL语言中,第一个被处理的子句是FROM子句,尽管SELECT语句第一个出现,但是几乎总是最后 ...
- Sql server 查询数据库中包含某字段的所有的表
我们有时候会需要查询数据库中包含某字段的所有的表,去进行update,这时就可以用下面的SQL来实现: select object_name(id) objName,Name as colName f ...
- SQL Server 查询数据库中被锁定的表
在一次测试过程中,发现有些表一直被锁定,从网上搜集了下资料,可以使用一下语句查看数据库中那些表正被锁定: select request_session_id spid,OBJECT_NAME(reso ...
- sql server查询数据库中所有表的行数
select a.name,b.rows from sysobjects a,sysindexes b where a.name = b.name order by b.rows desc
- SQL Server查询数据库中所有的表名及行数
SELECT a.name, b.rows FROM sysobjects AS a INNER JOIN sysindexes AS b ON a.id = b.id WHERE (a.type = ...
- MS Sql Server 查询数据库中所有表数据量
方法一: SELECT a.name,b.rows FROM sysobjects a INNER JOIN sysindexes b ON a.id=b.id ,) AND a.Type='u' O ...
- SQL Server查询中特殊字符的处理方法
SQL Server查询中,经常会遇到一些特殊字符,比如单引号“'”等,这些字符的处理方法,是SQL Server用户都应该需要知道的. 我们都知道SQL Server查询过程中,单引号“'”是特殊字 ...
- SQL Server查询中特殊字符的处理方法 (SQL Server特殊符号的转义处理)
SQL Server查询中特殊字符的处理方法 (SQL Server特殊符号的转义处理) SQL Server查询中,经常会遇到一些特殊字符,比如单引号'等,这些字符的处理方法,是SQL Server ...
随机推荐
- python下载IGS观测数据
最近在学习GPS数据软件处理,经常需要下载数据练习,反复去网站上很麻烦,于是就写了一个小小的爬虫,用的是韩国的服务器,使用了python中的ftplib库实现的 今天稍微改了一下代码,可以选择卫星系统 ...
- GitHub Desktop安装异常解决
为了更好的共同学习,共同进步,哥们推荐我使用GitHub记录自己每天的学习记录,当下很火的提供一个分布式的版本控制系统(Git)服务的网站,GitHub提供GitHub Desktop桌面程序方便协同 ...
- jsp页面表单的遍历要怎么写
1.传统的方式使用request.getAttribute(“list”);获取表单的值, 2.也可以用struts2提供的标签进行遍历 备注 // 传统的接受参数方法 // String sfz=t ...
- 常用的dos命令之简略总结
Dos常用命令 一.基础命令 1 dir 无参数:查看当前所在目录的文件和文件夹. /s:查看当前目录已经其所有子目录的文件和文件夹. /a:查看包括隐含文件的所有文件. /ah:只显示出 ...
- SVN Global ignore pattern 忽略文件正则后缀
*.o *.lo *.la *.al .libs *.so *.so.[0-9]* *.a *.pyc *.pyo __pycache__ *.rej *~ #*# .#* .*.swp .DS_St ...
- Java设计模式(学习整理)---策略模式
1. 模式定义 把会变化的内容取出并封装起来,以便以后可以轻易地改动或扩充部分,而不影响不需要变化的其他部分: 2.模式本质: 少用继承,多用组合,简单地说就是:固定不变的信息 ...
- NOIP2012 借教室 Splay初探
终于把区间操作的Splay搞明白了…… Splay的大致框架是这样的: [代码中的Zig-Zig和Zig-Zag操作其实是可以优化的,实际只需要3次passDown和3次update] templat ...
- MySQL的C++简单封装
/* *介绍:MySQL的简单封装,支持流操作输入输出MySQL语句,然而并没有什么软用,大二学生自娱自乐,有不足求指点 *作者:MrEO *日期:2016.3.26 */ 头文件 my_sql.h ...
- Xcode编译项目出现访问private key提示框
原因: 在编译时Xcode进行codesign时需要访问"private key"时没有权限,然后让询问是否允许,有三个选项,全部允许.否绝.允许,一次弹出4个(我遇到的) 遇到问 ...
- ICE学习第一步-----配置ICE环境变量
安装 ICE: 1.下载ICE: http://www.zeroc.com/download.html 下载说明:ICE支持语言(C++, Java, C#, Visual Basic,Python, ...