asp 隨機讀取ACCESS資料庫記錄的方法

來源:互聯網
上載者:User

檢查了一些貼子對於MSSQL資料庫教程一般可以採用這樣的語句:

 方法三:有這樣一種方法,我覺的不錯:
<%
yourstr="*1*3*4*6*12*...."
sql="select top 10 * form yourdb where instr('*'&id&'*','"&yourstr&"')<>0"
%>


  yourstr可以產生隨機數多一點大於所限定抽取的隨機數為好,這樣可以排除記錄不足的情況。

<%
n=10 '取任意10條記錄
set rs = server.createobject ("adodb.recordset")
sql = "select * from table"
rs.open sql,conn,1,1
count=rs.recordcount '記錄總數
if count<>empty then
randomize
for i=1 to n '迴圈n次
num=fix(rnd*count) 'num便是隨機產生的記錄行數,用fix(),使其不會大於count值
rs.move num '移到改隨機行
response.write rs(0) '出該條記錄
rs.movefirst '別忘了再把指標移到第一條
next
end if
rs.close
set rs=nothing
%>
<%
select top 50 * from someTable order by NewID()
%>


  但是如果是Access資料庫的話似乎沒有什麼好的解決方案。

   方法二:有人採用一條SQL語句解決此問題:
<%
select top 50 * from table order by int(rand()*50)
%>


  如果這條語句可行的話是個不錯的方法。我測試這條語句並沒有通過,如果有人知道是哪有問題請告訴我,非常感謝。

  方法:有人用如下代碼以記錄總數為極大值來首先提取出指定數量的隨機數,然後以這些隨機數做為記錄ID。
<%
dim n,j
dim su()
dim a,b,k
b=myrs.RecordCount
Randomize
redim su(index_N)
su(1)=Int((b * Rnd) + 1)
for n=2 to index_N
a=Int((b * Rnd) + 1)
for j=1 to n
do while a=su(j)
a=Int((b* Rnd) + 1)
j=1
loop
next
su(n)=a
next
%>


  這種方式有一些問題,就是當ID不是連續的話,有可能某些隨機數不存在ID序列當中。另外ID的最大值與總的記錄值不一定相等,這樣有些記錄ID會永遠被忽略。

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.