① sqlServer怎麼獲得生成的newid的值
在查詢分析器中執行:select rand(),可以看到結果會是類似於這樣的隨機小數:0.36361513486289558,像這樣的小數在實際應用中用得不多,一般要取隨機數都會 取隨機整數。那就看下面的兩種隨機取整數的方法:
A:select floor(rand()*N) ---生成的數是這樣的:12.0
B:select cast( floor(rand()*N) as int) ---生成的數是這樣的:12
A:select ceiling(rand() * N) ---生成的數是這樣的:12.0
B:select cast(ceiling(rand() * N) as int) ---生成的數是這樣的:12
大致一看,這兩種方法沒什麼區別,真的沒區別?其實是有一點的,那就是他們的生成隨機數的范圍:
方法1的數字范圍:0至N-1之間,如cast( floor(rand()*100) as int)就會生成0至99之間任一整數
方法2的數字范圍:1至N之間,如cast(ceiling(rand() * 100) as int)就會生成1至100之間任一整數
對於這個區別,看SQL的聯機幫助就知了:
② 在SQL Server數學函數中,獲取0~1之間的隨機值的函數是什麼
MSSQLSERVER如要獲取0~1之間的隨機數可以使用下列表達式:
Floor(2* Rand())
例如每次運行下列SQL語句,將隨機返回0或1
selectFloor(2*Rand());
請注意MSSQL的SQL語言,每次運行select,不論檢索出多少行,隨機函數rand都將返回相同的隨機數。
另外,需要返回某個指定范圍的隨機整數請參考下列公式:
Floor((upperbound - lowerbound + 1) * Rand() + lowerbound)
參數說明:
upperbound 為正整數上限
lowerbound 為正整數下限
Rand()為系統隨機函數
Floor()為系統函數,返回小於或等於所給數字表達式的最大整數。
有不同需要時,照套上述公式就可以了。
③ SqlServer函數的數學函數
trunc(45.923,1) 按指定精度截斷十進制數 結果:45.9 此為oracle函數
mod(1600,300) 求除法余數 結果:100
abs(numeric_expr) 求絕對值
ceiling(numeric_expr) 取大於等於指定值的最小整數
avg(numeric_expr)取平均數
exp(float_expr) 取指數
floor(numeric_expr) 小於等於指定值得最大整數
pi() 3.1415926.........
power(numeric_expr,power) 返回power次方
rand([int_expr]) 隨機數產生器
round(numeric_expr,int_expr) 安int_expr規定的精度四捨五入
sign(int_expr) 根據正數,0,負數,,返回+1,0,-1
sqrt(float_expr) 平方根
④ 關於java寫入SQLSERVER資料庫的一個超奇怪的問題
我覺得吧, 你應該在創建新用戶之前,用System.out.println(user.get****)去檢測一下,servlet從頁面上收集的信息和實際輸入的一不一樣。加在UserDAO = new UserDAO(); 這一句之前就可以, 為了保險起見,把用戶所有的信息都用system.out.println()輸出一遍。
如果顯示出的密碼和你輸入的是一致的話,那麼問題就是出在資料庫上。你用的是hibernate么?還是用sql語句往資料庫添加信息?如果是sql語句的話,就看看是不是添加用戶的sql語句中的password拼寫對不對,如果是hibernate的話,就看看那個xml配置文件里的password拼寫和屬性設置的對不對。
⑤ SQL語言隨機生成字元串的幾種方法
1.利用newid()產生的uniqueidentifier都是隨機且唯一的:declare @string nvarchar(100);set @string =cast(newid() as nvarchar(100));select @string;go2.利用rand()生成隨機數字串:declare @string nvarchar(100);set @string = right(str(rand(),8,6),2);select @string;go3.利用rand()生成6位隨機字元串:declare @sql nvarchar(400) select @sql= 'select char( '+cONVERT(NVARCHAR,CONVERT(INT,26*rand())+97)+ ')+ CHAR( '+CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97)+ ')+ CHAR( '+CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97)+ ')+ CHAR( '+CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97)+ ')+ CHAR( '+CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97)+ ')+ CHAR( '+CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97)+ ') ' print @sql EXEC(@sql) goDECLARE @Below int DECLARE @Up int SELECT @Below=65,@Up=90 SELECT CHAR(CAST(RAND()*(@Up-@Below)+@Below AS decimal(38,0))) +CHAR(CAST(RAND()*(@Up-@Below)+@Below AS decimal(38,0))) +CHAR(CAST(RAND()*(@Up-@Below)+@Below AS decimal(38,0))) +CHAR(CAST(RAND()*(@Up-@Below)+@Below AS decimal(38,0))) +CHAR(CAST(RAND()*(@Up-@Below)+@Below AS decimal(38,0))) +CHAR(CAST(RAND()*(@Up-@Below)+@Below AS decimal(38,0))) goSELECT CHAR(CONVERT(INT,rand()*26)+(CASE WHEN RAND()*2 > 1 THEN 97 ELSE 65 END))+ CHAR(CONVERT(INT,rand()*26)+(CASE WHEN RAND()*2 > 1 THEN 97 ELSE 65 END))+ CHAR(CONVERT(INT,rand()*26)+(CASE WHEN RAND()*2 > 1 THEN 97 ELSE 65 END))+ CHAR(CONVERT(INT,rand()*26)+(CASE WHEN RAND()*2 > 1 THEN 97 ELSE 65 END))+ CHAR(CONVERT(INT,rand()*26)+(CASE WHEN RAND()*2 > 1 THEN 97 ELSE 65 END))+ CHAR(CONVERT(INT,rand()*26)+(CASE WHEN RAND()*2 > 1 THEN 97 ELSE 65 END)) go4.編寫可以產生隨機字元串的存儲過程:--*********************CREATE VIEW V_RAND AS SELECT RAND1 = CONVERT(INT,RAND()*26),RAND2 = RAND()*2 GO CREATE FUNCTION DBO.f_GetRandNum(@LEN INT,@FLAG INT) RETURNS NVARCHAR(100) AS --@LEN 輸出字元的長度 --@FLAG 返回值包含字元 1:大寫字母 2:小寫字母 3:大小寫字母混合 BEGIN DECLARE @SQL NVARCHAR(100),@RAND INT SELECT @SQL = ' ' IF @LEN>100 SET @LEN = 100 WHILE @LEN>0 BEGIN SELECT @RAND = RAND1 +(CASE @FLAG WHEN 1 THEN 65 WHEN 2 THEN 97 ELSE(CASE WHEN RAND2 > 1 THEN 97 ELSE 65 END) END) FROM V_RAND SELECT @SQL=@SQL + CHAR(@RAND),@LEN = @LEN - 1 END RETURN @SQL END GO --調用存儲過程 SELECT DBO.f_GetRandNum(7,2) (收集自:CSDN社區)
⑥ 如何向SQLSERVER中進行update一組隨機數
這個還真不好做,因為sqlserver在0.5秒內,用同一種子,隨機函數會取到同一個數,
可能的話在表中新加一列,然後,列識成標志列,全填上數字。
然後用update 表名set 要改的列名=round (( 剛生成的列轉成字元,+ 秒數轉字元, 加時間轉字元)轉換成數字)
這樣一個近擬的效果,
⑦ sql 自定義函數返回0~100的隨機整數
SQL使用函數rand()產生隨機數,返回0~100的隨機整數使用下面的語句:
select cast(floor(rand() * 101) as int)
生成0至100之間任一整數
⑧ sqlserver創建函數 用表名+年月日+4位隨機數作為主鍵如何建立
SELECT (表名+getdate()+cast(rand() * (1000) AS int)) as value from t_table
sqlserver 應該有一個timestamp類型 那個是秒後面6位。。。 用那個其實就可以了
⑨ sqlserver查詢結果中增加和一個隨機序列怎麼做
select abs(checksum(newID())%100000) as No,Name from sysobjects where xtype='U'
⑩ sqlserver 中rand()是產生隨機數,為什麼還要設置種子
隨機函數rand可以認為是一個函數,只不過輸出的值看起來是隨機的罷了。對任何一個函數都需要輸入初始值x,對不同的初始值x對應不同的y,如一般C語言中採用rand(time(0))就是把當前時間作為初始值輸入,由於當前時間每次都不一樣,所以產生的隨機數每次也不一樣。sqlserver中rand()應該也是一個道理,一些不設置種子也可以的,是因為函數有默認種子。