SQLServer 随机生成指定范围的日期

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介: 一个分页的问题,DTCms3.0中,分页是根据时间分页的,如果当添加时间(add_time)都是同一个数值时,不管点击第几页,显示的数据都是同一个的内容,于是就有了需要把同一个时间改指定随机日期的功能。

一个分页的问题,DTCms3.0中,分页是根据时间分页的,如果当添加时间(add_time)都是同一个数值时,不管点击第几页,显示的数据都是同一个的内容,于是就有了需要把同一个时间改指定随机日期的功能。

原贴脚本转至http://bbs.csdn.net/topics/340165720 第7楼的feilniu同学.

SQL脚本如下: 

DECLARE  @BDate  datetime@EDate  datetime
SET  @BDate  =  ' 20150701 '           -- 下限
SET  @EDate  =  ' 20150714 23:59:59 '  -- 上限
SELECT id, random_datetime  =  DATEADD(second, ABS(CHECKSUM( NEWID())) % DATEDIFF(second, @BDate, @Edate), @BDate)
FROM dbo.dt_article
WHERE id  BETWEEN  1  AND  100 


 生成的内容为:

id random_datetime
3 2015-07-05 07:55:10.000
4 2015-07-08 06:15:06.000
9 2015-07-12 19:14:24.000
10 2015-07-11 20:13:05.000
12 2015-07-06 19:09:12.000
13 2015-07-09 10:28:59.000
14 2015-07-03 07:18:42.000
15 2015-07-06 09:46:29.000

 

此时的ID是对应dt_article表中的ID。

然后我们可以先把生成的数据写到临时表中,然后关联更新!

我们修改脚本如下:

 

SELECT id, random_datetime  =  DATEADD(second, ABS(CHECKSUM( NEWID())) % DATEDIFF(second, @BDate, @Edate), @BDate)
INTO # Temp 
FROM dbo.dt_article 

--更新日期
UPDATE dbo.dt_article   SET add_time =b.random_datetime
FROM dbo.dt_article a ,# Temp b
WHERE a.id =b.id
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
SQL 程序员
【Sql Server】来一波日期和时间函数,看看是否都知道
本篇文章主要了解下日期和时间函数,当前时间的前两天等设置
102 0
【Sql Server】来一波日期和时间函数,看看是否都知道
|
SQL Go 数据库
SQLServer数据库获取重复记录中日期最新的记录
在日常的项目开发当中,经常会遇到获取同一属性相同的记录,如何获取记录时间最新的那一条,比如获取某个淘宝用户最新一次的购物记录,美团外卖获取用户最后一次的点外卖记录等等场景,下面通过简单的示例给大家提供三种比较常见的SQL写法,希望能给大家带来一些思路。
SQLServer数据库获取重复记录中日期最新的记录
|
SQL
Sql Server函数全解<四>日期和时间函数
原文:Sql Server函数全解日期和时间函数   日期和时间函数主要用来处理日期和时间值,本篇主要介绍各种日期和时间函数的功能和用法,一般的日期函数除了使用date类型的参数外,也可以使用datetime类型的参数,但会忽略这些值的时间部分。
1336 0
|
SQL XML BI
在Sqlserver下巧用行列转换日期的数据统计
原文:在Sqlserver下巧用行列转换日期的数据统计                  在Sqlserver下巧用行列转换日期的数据统计   前言     在SQLSERVER 中有很多统计函数的基础语法,有使用Group By 或 partition by 后配合Sum,Count(*) 等用法。
1274 0
|
SQL Serverless C#
SQL SERVER 2005中如何获取日期(一个月的最后一日、上个月第一天、最后一天、一年的第一日等等)
原文:【转】SQL SERVER 2005中如何获取日期(一个月的最后一日、上个月第一天、最后一天、一年的第一日等等) 在网上找到的一篇文章,相当不错哦O(∩_∩)O~ //C#本周第一天            int dayOfWeek = Convert.
1369 0