本篇內(nèi)容介紹了“SQL Server中怎么生成一定范圍的隨機(jī)數(shù)”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
10余年的西市網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營(yíng)銷的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整西市建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)公司從事“西市網(wǎng)站設(shè)計(jì)”,“西市網(wǎng)站推廣”以來(lái),每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
方法一
select floor(rand()*N) ---生成的數(shù)是這樣的:12.0
select cast( floor(rand()*N) as int) ---生成的數(shù)是這樣的:12
方法二
select ceiling(rand() * N) ---生成的數(shù)是這樣的:12.0
select cast(ceiling(rand() * N) as int) ---生成的數(shù)是這樣的:12
其中里面的N是一個(gè)你指定的整數(shù),如100。
大致一看,這兩種方法沒(méi)什么區(qū)別,真的沒(méi)區(qū)別?其實(shí)是有一點(diǎn)的,那就是他們的生成隨機(jī)數(shù)的范圍:
方法1的數(shù)字范圍:0至N-1之間,如cast( floor(rand()*100) as int)就會(huì)生成0至99之間任一整數(shù)
方法2的數(shù)字范圍:1至N之間,如cast(ceiling(rand() * 100) as int)就會(huì)生成1至100之間任一整數(shù)
對(duì)于這個(gè)區(qū)別,看SQL的聯(lián)機(jī)幫助就知了:
------------------------------------------------------------------------------------
比較 CEILING 和 FLOOR
CEILING 函數(shù)返回大于或等于所給數(shù)字表達(dá)式的最小整數(shù)。FLOOR 函數(shù)返回小于或等于所給數(shù)字表達(dá)式的最大整數(shù)。例如,對(duì)于數(shù)字表達(dá)式 12.9273,CEILING 將返回 13,F(xiàn)LOOR 將返回 12。FLOOR 和 CEILING 返回值的數(shù)據(jù)類型都與輸入的數(shù)字表達(dá)式的數(shù)據(jù)類型相同。
----------------------------------------------------------------------------------
現(xiàn)在,各位就可以根據(jù)自己需要使用這兩種方法來(lái)取得隨機(jī)數(shù)了^_^
另外,還要提示一下各位,關(guān)于隨機(jī)取得表中任意N條記錄的方法,很簡(jiǎn)單,就用newid():
select top N * from table_name order by newid() ----N是一個(gè)你指定的整數(shù),表是取得記錄的條數(shù)
“SQL Server中怎么生成一定范圍的隨機(jī)數(shù)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!