sql 添加時間段內隨機時間

DECLARE @dt1 DATETIME,@dt2 DATETIME,@a BIGINT,@b BIGINT
SET @dt1='2010-01-01'--開始日期
SET @dt2='2010-06-30'--結束日期
 
SELECT @a=CAST(@dt1 AS BIGINT),@b=CAST(@dt2-@dt1 AS BIGINT)
 
DECLARE @t TABLE(ID INT,dt datetime)
 
DECLARE @i INT
SET @i=0
 
WHILE @i<100
BEGIN
    INSERT @t
    SELECT 
        @i+1,CAST(ABS(CHECKSUM(newID()))%@b+@a AS DATETIME)+RAND() 
    SET @i=@i+1
end
SELECT * FROM @t
年月日,時分秒 都是隨機的


修改評論中的時間

DECLARE @dt1 DATETIME,@dt2 DATETIME,@a BIGINT,@b BIGINT
SET @dt1='2010-01-01'--開始日期
SET @dt2='2010-06-30'--結束日期
 
SELECT @a=CAST(@dt1 AS BIGINT),@b=CAST(@dt2-@dt1 AS BIGINT)
update dbo.EvaluationReply SET  time= CAST(ABS(CHECKSUM(newID()))%@b+@a AS DATETIME)+RAND()

--修改時間中的時分秒爲創建時間的時分秒
UPDATE Evaluation SET Time=convert(char(10),Time,120)+' '+convert(char(8),CreateTime,114) 

寫個遊標修改評論下的回覆 時間,不能超過當前評論的時間

ALTER PROC [dbo].[Proc_UpdateEvaluationReplyCnt]
AS
BEGIN

DECLARE @id INT 
DECLARE @time DATETIME
DECLARE CURStaus1_PLAN CURSOR FOR
    --查詢所有用戶信息
        SELECT id,time FROM dbo.Evaluation 
        OPEN CURStaus1_PLAN
    FETCH NEXT FROM CURStaus1_PLAN INTO @id,@time
    WHILE (@@FETCH_STATUS = 0)
    BEGIN

DECLARE @dt1 DATETIME,@dt2 DATETIME,@a BIGINT,@b BIGINT
SET @dt1=CONVERT(varchar(100), @time, 23)--開始日期
SET @dt2=CONVERT(varchar(100), dateadd(day,7,@time), 23)--結束日期
 
SELECT @a=CAST(@dt1 AS BIGINT),@b=CAST(@dt2-@dt1 AS BIGINT)

UPDATE dbo.EvaluationReply SET  time=
CAST(ABS(CHECKSUM(newID()))%@b+@a AS DATETIME)+RAND()  where  EvaluationId=@id


    FETCH NEXT FROM CURStaus1_PLAN INTO @id,@time
    END 
    CLOSE CURStaus1_PLAN
    DEALLOCATE CURStaus1_PLAN
    
END

 

sql日期與隨機數問題的相關整理

SELECT * FROM NORTHWIND..ORDERS ORDER BY NEWID()
--隨機排序
SELECT TOP 10 * FROM NORTHWIND..ORDERS ORDER BY NEWID()
--從ORDERS 表中隨機取出10 條記錄
示例
A.對變量使用NEWID 函數
以下示例使用NEWID() 對聲明爲UNIQUEIDENTIFIER 數據類型的變量賦值。在測
試UNIQUEIDENTIFIER 數據類型變量的值之前,先輸出該值。
-- CREATING A LOCAL VARIABLE WITH DECLARESET SYNTAX.
DECLARE @MYID UNIQUEIDENTIFIER
SET @MYID = NEWID()
PRINT 'VALUE OF @MYID IS '+ CONVERT(VARCHAR(255), @MYID)
下面是結果集:
VALUE OF @MYID IS 6F9619FF-8B86-D011-B42D-00C04FC964FF
注意:
NEWID 對每臺計算機前往的值各不相同。所顯示的數字僅起解釋說明的作用。
隨機函數:RAND()
在查詢分析器中執行:SELECT RAND(),可以看到結果會是類似於這樣的隨機小數:
0.36361513486289558,像這樣的小數在實際應用中用得不多,一般要取隨機數都會取隨機
整數。那就看下面的兩種隨機取整數的方法:
1、
A:SELECT FLOOR(RAND()*N) ---生成的數是這樣的:12.0
B:SELECT CAST( FLOOR(RAND()*N) AS INT) ---生成的數是這樣的:12
2、
A:SELECT CEILING(RAND() * N) ---生成的數是這樣的:12.0
B:SELECT CAST(CEILING(RAND() * N) AS INT) ---生成的數是這樣的:12
其中裏面的N 是一個你指定的整數,如100,可以看出,兩種方法的A 方法是帶有.0
這個的小數的,而B 方法就是真正的整數了。
大致一看,這兩種方法沒什麼區別,真的沒區別?其實是有一點的,那就是他們的生成隨機
數的範圍:
方法1 的數字範圍:0 至N-1 之間,如CAST( FLOOR(RAND()*100) AS INT)就會生成0
至99 之間任一整數
方法2 的數字範圍:1 至N 之間,如CAST(CEILING(RAND() * 100) AS INT)就會生成1
至100 之間任一整數
對於這個區別,看SQL 的聯機幫助就知了:
比較CEILING 和FLOOR
CEILING 函數前往大於或等於所給數字表達式的最小整數。FLOOR 函數前往小於或
等於所給數字表達式的最大整數。例如,對於數字表達式12.9273,CEILING 將前往13,
FLOOR 將前往12。FLOOR 和CEILING 前往值的數據類型都與輸入的數字表達式的數
據類型相同。
現在,各位就可以根據自己需要使用這兩種方法來取得隨機數了^_^
另外,還要提示一下各位菜鳥,關於隨機取得表中任意N 條記錄的方法,很簡單,就
用NEWID():
SELECT TOP N * FROM TABLE_NAME ORDER BY NEWID() ----N 是一個你指定的整
數,表是取得記錄的條數.
舉例:
經過測試發現:
if object_id('tb') is not null
drop table tb
create table tb (s_id int,t_id int, fenshu int)
insert into tb
select 1,1,66 union all
select 1,2,67 union all
select 2,1,65 union all
select 2,2,78 union all
select 3,1,66 union all
select 3,2,55
--這個方法可以給不同數加上不同隨機數(newid( ))
select fenshu,(fenshu+cast(ceiling(RAND(CHECKSUM(NEWID()))*10)as int))as fenshu
from tb
--這個方法只能給不同數隨機加上相同數(RAND( ))
select fenshu,(fenshu+cast(CEILING(RAND() * 10) AS INT))as fenshu
from tb
或者
SELECT fenshu,fenshu+cast(ceiling(RAND(CHECKSUM(rand()))*10) as int) fenshu2
FROM tb
/*------------
66 68
67 74
65 75
78 80
66 73
55 58
66 68
67 69
65 67
78 80
66 68
55 57
------------*/

 

Sql Server 中一個非常強大的日期格式化函數

字符串轉日期
Select cast('2009-01-01' as datetime)

日期格式轉換
Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM
Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06
Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16
Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06
Select CONVERT(varchar(100), GETDATE(), 4): 16.05.06
Select CONVERT(varchar(100), GETDATE(), 5): 16-05-06
Select CONVERT(varchar(100), GETDATE(), 6): 16 05 06
Select CONVERT(varchar(100), GETDATE(), 7): 05 16, 06
Select CONVERT(varchar(100), GETDATE(),icon_cool.gif: 10:57:46
Select CONVERT(varchar(100), GETDATE(), 9): 05 16 2006 10:57:46:827AM
Select CONVERT(varchar(100), GETDATE(), 10): 05-16-06
Select CONVERT(varchar(100), GETDATE(), 11): 06/05/16
Select CONVERT(varchar(100), GETDATE(), 12): 060516
Select CONVERT(varchar(100), GETDATE(), 13): 16 05 2006 10:57:46:937
Select CONVERT(varchar(100), GETDATE(), 14): 10:57:46:967
Select CONVERT(varchar(100), GETDATE(), 20): 2006-05-16 10:57:47
Select CONVERT(varchar(100), GETDATE(), 21): 2006-05-16 10:57:47.157
Select CONVERT(varchar(100), GETDATE(), 22): 05/16/06 10:57:47 AM
Select CONVERT(varchar(100), GETDATE(), 23): 2006-05-16
Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47
Select CONVERT(varchar(100), GETDATE(), 25): 2006-05-16 10:57:47.250
Select CONVERT(varchar(100), GETDATE(), 100): 05 16 2006 10:57AM
Select CONVERT(varchar(100), GETDATE(), 101): 05/16/2006
Select CONVERT(varchar(100), GETDATE(), 102): 2006.05.16
Select CONVERT(varchar(100), GETDATE(), 103): 16/05/2006
Select CONVERT(varchar(100), GETDATE(), 104): 16.05.2006
Select CONVERT(varchar(100), GETDATE(), 105): 16-05-2006
Select CONVERT(varchar(100), GETDATE(), 106): 16 05 2006
Select CONVERT(varchar(100), GETDATE(), 107): 05 16, 2006
Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49
Select CONVERT(varchar(100), GETDATE(), 109): 05 16 2006 10:57:49:437AM
Select CONVERT(varchar(100), GETDATE(), 110): 05-16-2006
Select CONVERT(varchar(100), GETDATE(), 111): 2006/05/16
Select CONVERT(varchar(100), GETDATE(), 112): 20060516
Select CONVERT(varchar(100), GETDATE(), 113): 16 05 2006 10:57:49:513
Select CONVERT(varchar(100), GETDATE(), 114): 10:57:49:547
Select CONVERT(varchar(100), GETDATE(), 120): 2006-05-16 10:57:49
Select CONVERT(varchar(100), GETDATE(), 121): 2006-05-16 10:57:49.700
Select CONVERT(varchar(100), GETDATE(), 126): 2006-05-16T10:57:49.827
Select CONVERT(varchar(100), GETDATE(), 130): 18 ???? ?????? 1427 10:57:49:907AM
Select CONVERT(varchar(100), GETDATE(), 131): 18/04/1427 10:57:49:920AM


常用:
Select CONVERT(varchar(100), GETDATE(),icon_cool.gif: 10:57:46
Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47
Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49
Select CONVERT(varchar(100), GETDATE(), 12): 060516
Select CONVERT(varchar(100), GETDATE(), 23): 2006-05-16

1.  當前系統日期、時間 
None.gif    select getdate()  
None.gif
None.gif2. dateadd  在向指定日期加上一段時間的基礎上,返回新的 datetime 值
None.gif   例如:向日期加上2天 
None.gif   select dateadd(day,2,'2004-10-15')  --返回:2004-10-17 00:00:00.000 
None.gif
None.gif3. datediff 返回跨兩個指定日期的日期和時間邊界數。
None.gif   select datediff(day,'2004-09-01','2004-09-18')   --返回:17
None.gif
None.gif4. datepart 返回代表指定日期的指定日期部分的整數。
None.gif  select DATEPART(month, '2004-10-15')  --返回 10
None.gif
None.gif5. datename 返回代表指定日期的指定日期部分的字符串
None.gif   select datename(weekday, '2004-10-15')  --返回:星期五
None.gif
None.gif6. day(), month(),year() --可以與datepart對照一下
None.gif
None.gifselect 當前日期=convert(varchar(10),getdate(),120) 
None.gif,當前時間=convert(varchar(8),getdate(),114) 
None.gif
None.gifselect datename(dw,'2004-10-15') 
None.gif
None.gifselect 本年第多少周=datename(week,'2004-10-15')
None.gif      ,今天是周幾=datename(weekday,'2004-10-15')

 

函數 參數/功能
GetDate( ) 返回系統目前的日期與時間
DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 與date1兩個日期之間的差值 date2-date1
DateAdd (interval,number,date) 以interval指定的方式,加上number之後的日期
DatePart (interval,date) 返回日期date中,interval指定部分所對應的整數值
DateName (interval,date) 返回日期date中,interval指定部分所對應的字符串名稱

參數 interval的設定值如下:

縮 寫(Sql Server) Access 和 ASP 說明
Year Yy yyyy 年 1753 ~ 9999
Quarter Qq 季 1 ~ 4
Month Mm 月1 ~ 12
Day of year Dy y 一年的日數,一年中的第幾日 1-366
Day Dd 日,1-31
Weekday Dw w 一週的日數,一週中的第幾日 1-7
Week Wk ww 周,一年中的第幾周 0 ~ 51
Hour Hh 時0 ~ 23
Minute Mi 分鐘0 ~ 59
Second Ss s 秒 0 ~ 59
Millisecond Ms - 毫秒 0 ~ 999
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章