傳說用這個語句管用:select top 5 * from tablename order by newid()
我放到sql的查詢分析器裡去執行果然管用,隨機抽取5條信息,不停的換,結果我應用到程序裡的時候就不管用了,總是那幾條,於是對這個東西進行了一個研究得出另一種方法:
newid() 可以產生如:"49869293-8891-4B31-B88E-A584D9621490” 這樣的數據結果,而且每一行產生的都不同,這樣的話,我們就可以在查詢的時候給結果集裡加上這麼一個列,比如:
select *,newsid() from 表名
然後我們在給這個結果集排序,因為每次newid()所產生的值都不同,所以如果排序的話,每次當然也都不一樣,這樣我們就可以隨機挑選幾條數據了,那我們在從前面加上一個top 語句就變成了:
復制代碼 代碼如下:
select top 10 *, NewID() as random from 表名 order by random
用這樣的方法就可以得到。我們想要結果了。不信的話你可以去試試。