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(),: 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(),: 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. 當前系統日期、時間
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')
函數 | 參數/功能 |
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 | q | 季 1 ~ 4 | |
Month | Mm | m | 月1 ~ 12 |
Day of year | Dy | y | 一年的日數,一年中的第幾日 1-366 |
Day | Dd | d | 日,1-31 |
Weekday | Dw | w | 一週的日數,一週中的第幾日 1-7 |
Week | Wk | ww | 周,一年中的第幾周 0 ~ 51 |
Hour | Hh | h | 時0 ~ 23 |
Minute | Mi | n | 分鐘0 ~ 59 |
Second | Ss | s | 秒 0 ~ 59 |
Millisecond | Ms | - | 毫秒 0 ~ 999 |