全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:924
推到 Plurk!
推到 Facebook!

如何隨機取出n筆資料??

尚未結案
jayko
一般會員


發表:2
回覆:5
積分:1
註冊:2004-05-30

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-06-13 23:16:48 IP:61.221.xxx.xxx 未訂閱
我要以隨機的方式取出num欄位值的筆數資料,請問要如何下select指令?? 如:有一table A 欄位num中的值為 4,則隨機取出4筆資料;若num中的值為5,則取出5筆資料。即=> select top $$ * from A order by Newid() 中$$是根據Table A 欄位num中某一筆的值決定。
Stallion
版主


發表:52
回覆:1600
積分:1995
註冊:2004-09-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-06-13 23:50:03 IP:211.22.xxx.xxx 未訂閱
 var
    i:integer;
    SQLString:String        i := Random(5)   1; // Random(5) 的值介於 0 - 4
    SQLString := 'Select Top '   intToStr(i)   ' from A order by Newid';
----------------------------------------------- Creation is the fundation of promotion.
h@visli
資深會員


發表:103
回覆:429
積分:431
註冊:2004-02-13

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-06-14 09:48:02 IP:222.248.xxx.xxx 未訂閱
能不能給出表A的具體結構與一些示例資料?
------
------------------------
博采眾家之長,奉獻綿薄之力
------------------------
jayko
一般會員


發表:2
回覆:5
積分:1
註冊:2004-05-30

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-06-14 11:50:52 IP:163.23.xxx.xxx 未訂閱
引言: 能不能給出表A的具體結構與一些示例資料?
我的表A大概是 chapter num -------------- Ch1 4 Ch2 5 Ch3 1
jayko
一般會員


發表:2
回覆:5
積分:1
註冊:2004-05-30

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-06-14 11:57:59 IP:220.130.xxx.xxx 未訂閱
引言:
 var
    i:integer;
    SQLString:String        i := Random(5)   1; // Random(5) 的值介於 0 - 4
    SQLString := 'Select Top '   intToStr(i)   ' from A order by Newid';
----------------------------------------------- Creation is the fundation of promotion.
我想大大誤會了, 我想要的是從db table 中的某筆資料的值來決定隨機取出的資料筆數…
jimmy_wei
高階會員


發表:9
回覆:176
積分:147
註冊:2003-08-28

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-06-14 12:23:19 IP:210.243.xxx.xxx 未訂閱
請問你的資料庫是什麼??
jayko
一般會員


發表:2
回覆:5
積分:1
註冊:2004-05-30

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-06-14 12:46:33 IP:163.23.xxx.xxx 未訂閱
引言: 請問你的資料庫是什麼??
MS-SQL Server
h@visli
資深會員


發表:103
回覆:429
積分:431
註冊:2004-02-13

發送簡訊給我
#8 引用回覆 回覆 發表時間:2005-06-14 15:18:42 IP:222.248.xxx.xxx 未訂閱
難度在於Top後要跟一個整形數字,所以如果直接採用SQL語句寫的話有困難,我試用過存儲過程也不行。所以推薦試試下面的方法:    首先,寫一個存儲過程: CREATE procedure TopNumber @tn integer output as select @tn=num from a where ……//你的查詢條件  GO    然後在代碼中:
var
  TopNb: integer;
Begin
  ……
  ADOStoredProc1.ProcedureName := 'TopNumber;1';
  ADOStoredProc1.ExecProc;
  TopNb := ADOStoredProc1.Parameters.ParamByName('tn').Value;
  ADOQuery1.SQL.Clear;
  ADOQuery1.SQL.Add('select top '   inttostr(TopNb)   ' * from A order by Newid');
  ADOQuery1.Open;
end;
代碼沒有測試過! 發表人 - h@visli 於 2005/06/14 15:21:39
------
------------------------
博采眾家之長,奉獻綿薄之力
------------------------
h@visli
資深會員


發表:103
回覆:429
積分:431
註冊:2004-02-13

發送簡訊給我
#9 引用回覆 回覆 發表時間:2005-06-16 14:38:36 IP:222.248.xxx.xxx 未訂閱
改寫一下 CREATE procedure TopNumber as declare @tn integer set @tn= select num from a where ...... exec('select top ' @tn ' * from a ......') GO 發表人 - h@visli 於 2005/06/16 14:40:03
------
------------------------
博采眾家之長,奉獻綿薄之力
------------------------
系統時間:2024-06-29 22:42:35
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!