• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > SQL 判断给定日期值(或时间段)所在星期的星期一和星期天的日期

SQL 判断给定日期值(或时间段)所在星期的星期一和星期天的日期

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了日期,星期等相关知识,希望本文的分享对您有所帮助

最近报表要用到一项功能,需要把数据源根据记录发生日期所在的星期序列进行分组。因此就写了两个相关SQL Function进行调用。

一、给定一个日期值,求出此日期所在星期的星期一和星期天的日期数据
例如给定一个日期 2010-09-01,求出它所在星期的星期一是2010-08-30,星期天是2010-09-05

Function创建如下:
代码如下:
USE [MSSQL]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[My_OneDay_GetWeekFirstAndEndDay](@tmpDate DATETIME)
RETURNS @tmpTable TABLE(FirstDay DATETIME , EndDay DATETIME)
AS
BEGIN
INSERT INTO @tmpTable
SELECT a.FirstDay,b.EndDay FROM (
SELECT 1 AS ID,DATEADD(wk, DATEDIFF(wk,0,@tmpDate), 0) AS FirstDAy
) a
LEFT JOIN (
SELECT 1 AS ID,DATEADD(wk, DATEDIFF(wk,0,@tmpDate), 6) AS EndDay
) b
ON a.ID = b.ID
RETURN
End

Function测试:
代码如下:
SELECT * from My_OneDay_GetWeekFirstAndEndDay('2010-09-01')

二、以上面单个日期搜索为基础,由用户输入两个参数,一个是开始日期,一个结束日期,根据这两个参数,求出在此时期段内的所有星期的星期一和星期天的日期表并排序。
例如开始日期是2011-09-01,结束日期是2011-10-06,我们就可以得到此星期表如下:
WeekOrder FirstDay EndDay
1 2011-08-29 00:00:00.000 2011-09-04 00:00:00.000
2 2011-09-05 00:00:00.000 2011-09-11 00:00:00.000
3 2011-09-12 00:00:00.000 2011-09-18 00:00:00.000
4 2011-09-19 00:00:00.000 2011-09-25 00:00:00.000
5 2011-09-26 00:00:00.000 2011-10-02 00:00:00.000
6 2011-10-03 00:00:00.000 2011-10-09 00:00:00.000

Function创建如下:
代码如下:
USE [MSSQL]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE FUNCTION [dbo].[MY_Range_GetWeekFirstAndEndDays](@tmpDateSTART DATETIME,@tmpDateEND DATETIME)
RETURNS @tmpTable TABLE(WeekOrder INT,FirstDay DATETIME , EndDay DATETIME)
AS
BEGIN
DECLARE @tmpDate DATETIME
DECLARE @index INT
SET @tmpDate=@tmpDateSTART
SET @index=1
WHILE @tmpDate <=@tmpDateEND
BEGIN
INSERT INTO @tmpTable
SELECT @index,a.FirstDay,b.EndDay FROM (
SELECT 1 AS ID,DATEADD(wk, DATEDIFF(wk,0,@tmpDate), 0) AS FirstDAy) a
LEFT JOIN (
SELECT 1 AS ID,DATEADD(wk, DATEDIFF(wk,0,@tmpDate), 6) AS EndDay) b
ON a.ID = b.ID

SET @tmpDate=DATEADD(DAY,7,@tmpDate)
SET @index=@index+1
END
RETURN
End

Function测试:
代码如下:
SELECT * from My_Range_GetWeekFirstAndEndDays('2011-09-01','2011-10-06')
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 关于mysql 的时间类型选择
  • SQL SERVER 日期格式转换详解
  • 浅谈SQLite时间函数的使用说明与总结分析
  • mysql截取函数常用方法使用说明
  • MySQL 获得当前日期时间的函数小结
  • mysql中取系统当前时间,当前日期方便查询判定的代码
  • Mysql中日期和时间函数应用不用求人
  • mysql的日期和时间函数
  • mysql时间戳转成常用可读时间格式的两种方法
  • MySQL日期数据类型、时间类型使用总结

相关文章

  • 2018-12-05JDBC如何连接MySQL数据库?
  • 2018-12-05Mac下MySQL安装配置图解
  • 2018-12-05详解MySQL存储过程参数有三种类型(in、out、inout)
  • 2017-05-11MySQL前缀索引导致的慢查询分析总结
  • 2018-12-05MySql的索引操作
  • 2018-12-05Oracle 10g各个帐号的访问权限、登录路径、监控状态命令查询等等
  • 2018-12-05Oracle 自增(auto increment) 或 标识字段的建立方法_Oracle应用
  • 2017-05-11mysql处理添加外键时提示error 150 问题的解决方法
  • 2018-12-05分享SQL Server删除重复行的6个方法
  • 2017-05-11MySQL笔记之触发器的应用

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL如何查看连接数和连接状态
    • MySQL服务器进程CPU占用100%的解决方法
    • mysql的数据类型有哪些?mysql数据类型详解
    • Oracle数据库的备份与恢复
    • mysql order by rand() 效率优化方法
    • mysql查找新插入的一条数据在表中的位置及扩展
    • [教程]MongoDB 从入门到进阶 (数据检索及统计
    • 重置MySQL数据库root密码(linux/windows)
    • mysql 常用设置 字符集编码、自动完成(自动提示)、监听外网ip
    • mysql中关于alter命令的使用详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有