1. 本月的第一天
SELECT  DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0)

2. 本月的最后一天
SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(m,0,getdate())+1,  0))

3.上个月的第一天
select dateadd(m,-1,  DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0))

4. 上个月的最后一天 
SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0))

5. 本周的星期一
SELECT  DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0)

6.本周的周日
select dateadd(d,+6 ,DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0) )

7.上周的星期一
select dateadd(d,-7 ,DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0) )

8.上周的周日
select dateadd(d,-1 ,DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0) )

9. 一年的第一天
SELECT  DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0)

10. 季度的第一天
SELECT  DATEADD(qq,  DATEDIFF(qq,0,getdate()),  0)

11. 去年的最后一天
SELECT  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0))

12. 本月的第一个星期一
select  DATEADD(wk,  DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate)),getdate))),0)

13. 本年的最后一天
SELECT  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate())+1,  0))。

Sql Server中的日期与时间函数 
1.  当前系统日期、时间 
    select getdate()

2. dateadd  在向指定日期加上一段时间的基础上,返回新的 datetime 值
   例如:向日期加上2天 
   select dateadd(day,2,'2004-10-15')  --返回:2004-10-17 00:00:00.000

3. datediff 返回跨两个指定日期的日期和时间边界数。
   select datediff(day,'2004-09-01','2004-09-18')   --返回:17

4. datepart 返回代表指定日期的指定日期部分的整数。
  SELECT DATEPART(month, '2004-10-15')  --返回 10

5. datename 返回代表指定日期的指定日期部分的字符串
   SELECT datename(weekday, '2004-10-15')  --返回:星期五

6. day(), month(),year() --可以与datepart对照一下

select 当前日期=convert(varchar(10),getdate(),120) 
,当前时间=convert(varchar(8),getdate(),114)

select datename(dw,'2004-10-15')

select 本年第多少周=datename(week,'2004-10-15')
      ,今天是周几=datename(weekday,'2004-10-15')

http://www.52186.cn/nibablog/blogview.asp?logID=333

sql日期格式转换

--------------------------------------------------------------------------------
来源:CSDN   发布会员:新书城收集整理   发布时间:2006-7-31   人气:384
 
 
在sql中,smalldatetime及datetime型的数据显示不是那么让人满意,因此我找了些格式化的方法列出来"

convert(char(10),datetime,101)

在数据库取出来的时候就转换好
 select getdate()
 
 2006-05-12 11:06:08.177
 
 我整理了一下SQL Server里面可能经常会用到的日期格式转换方法:
 
 举例如下:
 select Convert(varchar(10),getdate(),120)

2006-05-12 
 select CONVERT(varchar, getdate(), 120 )
 2006-05-12  11:06:08

select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','')
 20060512110608
 
 select CONVERT(varchar(12) , getdate(), 111 )
 2006/05/12
 
 select CONVERT(varchar(12) , getdate(), 112 )
 20060512

select CONVERT(varchar(12) , getdate(), 102 )
 2006.05.12
 
 其它几种不常用的日期格式转换方法:

select CONVERT(varchar(12) , getdate(), 101 )
 0612/2005 select CONVERT(varchar(12) , getdate(), 103 )
 12/09/2004

select CONVERT(varchar(12) , getdate(), 104 )
 12.05.2006

select CONVERT(varchar(12) , getdate(), 105 )
 12-05-2006

select CONVERT(varchar(12) , getdate(), 106 )
 12 05 2006

select CONVERT(varchar(12) , getdate(), 107 )
 05 12, 2006

select CONVERT(varchar(12) , getdate(), 108 )
 11:06:08
 
 select CONVERT(varchar(12) , getdate(), 109 )
 0512 2006 1

select CONVERT(varchar(12) , getdate(), 110 )
 09-12-2004

select CONVERT(varchar(12) , getdate(), 113 )
 12 052006

select CONVERT(varchar(12) , getdate(), 114 )
 11:06:08.177

============================================================================================
实例演练

select * from salesmb
select count(*) from salesdreport where employeeid='11'and productsid='7' and (updatetime between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --销售数量
select sum(sales) from salesmb where eid='11'and productsid='7' and (mbrq between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --目标数量

select dateadd(d,-day(getdate()),getdate())

select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-'+cast(day(getdate()) as varchar)

select dateadd(m,1,dateadd(d,-day(getdate()),getdate()))

select dateadd(m,1,getdate())

=====================================================================================================================================================

select * from salesmb
select count(*) from salesdreport where employeeid='11'and productsid='7' and (updatetime between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --销售数量
select sum(sales) from salesmb where eid='11'and productsid='7' and (mbrq between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --目标数量

select dateadd(d,-day(getdate()),getdate())

select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-'+cast(day(getdate()) as varchar)

select dateadd(m,1,dateadd(d,-day(getdate()),getdate()))

select dateadd(m,1,getdate())

======================================================================================================================================================

select * from salesmb
select count(*) from salesdreport where employeeid='11'and productsid='7' and (updatetime between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --销售数量
select sum(sales) from salesmb where eid='11'and productsid='7' and (mbrq between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --目标数量

select dateadd(d,-day(getdate()),getdate())

select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-'+cast(day(getdate()) as varchar)

select dateadd(m,1,dateadd(d,-day(getdate()),getdate()))

select dateadd(m,1,getdate())

===============================================================================================================================

select getdate()
select dateadd(d,1,dateadd(d,-day(getdate()),getdate()))+"00:00"

declare @sdate smalldatetime
select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
select @sdate
select dateadd(day,-1,dateadd(Month,1,@sdate))

select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'

select dateadd(d,-day(getdate()),getdate())

select dateadd(day,-1,dateadd(Month,1,cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'))

select dateadd(d,-day(getdate()),getdate())

select dateadd(d,1,dateadd(d,-day(getdate()),getdate()))
select dateadd(m,

SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
SELECT dateadd(ms,0,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))

原文出处:http://www.cnblogs.com/qfb620/archive/2008/02/26/1082644.html

[转载]SQL语句中的日期计算的更多相关文章

  1. 存储过程往拼接的sql语句中传递日期值

    存储过程往拼接的sql语句中传递日期值 declare @start datetime declare @end datetime set @start='2014-3-1' set @end='20 ...

  2. 数据库SQL语句中根据当前日期计算其他日期小结

    问题描述:我们在写存储过程和函数的时候经常会碰到利用当前日期计算出上周开始日期.结束日期,或者计算上个月的开始日期结束日期等问题.最近写了几个存储过程和函数,其中都涉及到了日期计算问题,在这里简单做一 ...

  3. SQL语句中关于日期的操作(非常的有用)

    在SQL Server 里的日期数据,我们经常可以用 字段<='2008-5-20'这样的表达式,但在oracle却不可以,因为数据类型不一样 字段是date型,'2008-5-20'是字符型, ...

  4. SQL语句中的日期查询

    我们先创建一个表: CREATE TABLE `student` ( `id` INT NOT NULL AUTO_INCREMENT , `name` VARCHAR(10) NULL COMMEN ...

  5. SQL语句中日期的计算方法大全

    sql语句中的日期处理一.日期處理函數1.日期增減函數 dateadd(datepart,number,dtae) datepart:是規定應向日期的哪一部分返回新值的參數.下列是sql server ...

  6. sql语句中获取datetime的日期部分或时间部分

    sql语句中获取datetime的日期部分 sql语句中 经常操作操作datetime类型数据.今天在写一个存储过程的时候需要将 一个datetime的值的 日期部分提取出来.网上有许多这方面的介绍. ...

  7. (转载)总结一下SQL语句中引号(')、quotedstr()、('')、format()在SQL语句中的用法

    总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中的用法 总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中 ...

  8. (转载)SQL语句中Group by语句的详细介绍

    转自:http://blog.163.com/yuer_d/blog/static/76761152201010203719835 SQL语句中Group by语句的详细介绍              ...

  9. (转载)总结一下SQL语句中引号(')、quotedstr()、('')、format()在SQL语句中的用法

    总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中的用法以及SQL语句中日期格式的表示(#).('')在Delphi中进行字符变量连接相加时单引号用('' ...

随机推荐

  1. ABP文档 - 异常处理

    文档目录 本节内容: 简介 启用错误处理 非AJAX请求 显示异常 UserFriendlyException Error 模型 AJAX 请求 异常事件 简介 这个文档针对Asp.net Mvc和W ...

  2. ExtJS 4.2 组件介绍

    目录 1. 介绍 1.1 说明 1.2 组件分类 1.3 组件名称 1.4 组件结构 2. 组件的创建方式 2.1 Ext.create()创建 2.2 xtype创建 1. 介绍 1.1 说明 Ex ...

  3. SVD奇异值分解的基本原理和运用

    SVD奇异值分解: SVD是一种可靠的正交矩阵分解法.可以把A矩阵分解成U,∑,VT三个矩阵相乘的形式.(Svd(A)=[U*∑*VT],A不必是方阵,U,VT必定是正交阵,S是对角阵<以奇异值 ...

  4. BPM费控管理解决方案分享

    一.方案概述费用是除经营成本外企业的最主要支出,费用管理是财务管理的核心之一,加强企业内控管理如:费用申请.费用报销.费用分摊.费用审批.费用控制和费用支付等,通过科学有效的管理方法规范企业费用管理, ...

  5. iOS -- CocoaPods

    CocoaPods 是什么? CocoaPods 是一个负责管理 iOS 项目中第三方开源库的工具.CocoaPods 的项目源码在 GitHub( https://github.com/CocoaP ...

  6. Linux下编译安装Vim8.0

    什么是Vim? Vim 是经典的 UNIX 编辑器 Vi 的深度改良版本.它增加了许多功能,包括:多级撤销.格式高亮.命令行历史.在线帮助.拼写检查.文件名补完.块操作.脚本支持,等等.除了字符界面版 ...

  7. Jquery对网页高度、宽度的操作

    Jquery获取网页的宽度.高度 网页可见区域宽: document.body.clientWidth 网页可见区域高: document.body.clientHeight 网页可见区域宽: doc ...

  8. Xamarin体验:使用C#开发iOS/Android应用

    Xamarin是Mono创始人Miguel de Icaza创建的公司,旨在让开发者可以用C#编写iOS, Android, Mac应用程序,也就是跨平台移动开发.   简介 Xamarin是基于Mo ...

  9. centos6.X使用Apache+Mono搭建asp.net 环境

    mark 一下时间  2016年1月19日09:42:49 mono是指由Novell公司(由Xamarin发起,并由Miguel de lcaza领导的,一个致力于开创·NET在Linux上使用的开 ...

  10. 【转】ofbiz数据库表结构设计

    真心不错的文章,可以加深对企业信息化的设计理解:) http://blog.sina.com.cn/s/blog_a2ca5d8c01017fa0.html http://blog.sina.com. ...