青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長網(wǎng)

17站長網(wǎng) 首頁 數(shù)據(jù)庫 Access 查看內(nèi)容

MS SQL Server和Access分別取得隨機記錄

2023-3-16 16:46| 查看: 1592 |來源: 互聯(lián)網(wǎng)

這是博主用在一個項目上的源碼片斷,無論是速度、均衡性,還是隨機度都非常好,當然這更不可能抽到重復(fù)記錄了。一、在MS SQL Server 2000中生成隨機記錄的最好辦 ...

這是博主用在一個項目上的源碼片斷,無論是速度、均衡性,還是隨機度都非常好,當然這更不可能抽到重復(fù)記錄了。

一、在MS SQL Server 2000中生成隨機記錄的最好辦法:

with tk_query do

begin

Close;

sql.clear;

sql.Add('select top '+inttostr(st_count)+' tk.ID,標準答案 from 題庫表 tk');

sql.Add('where pid is null and tk.題型='+quotedstr(tx)+' and tk.知識點='+quotedstr(zsd));

sql.add('and tk.難易度='+quotedstr(nyd)+' and tk.課程號='+quotedstr(kcdm)+' order by newid()');

Open;

end;

注:關(guān)鍵就是 order by newid() 這條語句!隨機因子就是從這里產(chǎn)生的。

二、數(shù)據(jù)庫為Access2000時生成隨機記錄的最好辦法:

由于Access中沒有newid()這一隨機函數(shù),故要想在Access中直接由SQL語句生成我們所希望的隨機記錄不太可能,因此我們只好在開發(fā)語言中生成合適SQL語句,讓Access執(zhí)行了(博主的開發(fā)工具為Delphi)。

//獲取題庫表中的隨機ID,組成一個字符串,類似這樣 (3,8,2,25,49,1,7,10,6,83....)

//kcdm:課程代碼,tx:題型,zsd:知識點,nyd:難易度,t_count:某一題型某一知識點某一難度下的要抽取的題量

function TTest_Srv_RDataForm.Get_Random_ID(const kcdm,tx,zsd,nyd,t_count:string):string;

var

sl: TStrings;

i,ii,kk: integer;

begin

try

Result := '';

sl := TStringList.Create;

with TADOQuery.Create(nil) do

begin

try

Connection := Adoconnection1;

SQL.Text := ' select ID from 題庫表 where pid is null and 題型='+quotedstr(tx)+

' and 知識點='+quotedstr(zsd)+' and 難易度='+quotedstr(nyd)+

' and 課程號='+quotedstr(Kcdm);

Open;

while not Eof do

begin

sl.Add(Fields[0].AsString);

Next;

end;

Close;

finally

Free;

end;

end; //end with ....

if sl.Count=0 then

Exit;

for i := 0 to StrToIntDef(t_count,0)-1 do

begin

kk := sl.Count;//隨機因子

Randomize;

ii := Random(kk); //取得隨機數(shù)

if Result='' then

Result := sl.Strings[ii]

else

Result := Result+','+sl.Strings[ii];

sl.Delete(ii); //為了避免有可能出現(xiàn)的重復(fù),此ID被抽取過后把它刪了

if sl.Count=0 then //如果無題可抽了退出循環(huán)

Break;

end;

Result := '('+Result+')'; //給結(jié)果串前后加上(......),最終形成(24,36,5,89,72,3,6,1....)的串樣

finally

sl.Free;

end;

end;

//=============================================== 課程號,題型,知識點,難易度,題量

function TTest_Srv_RDataForm.Get_Random_Sql(const kcdm,tx,zsd,nyd,t_count:string):string;

begin

Result := Get_Random_ID(kcdm,tx,zsd,nyd,t_count);

if Result <> '' then

Result := ' select top '+t_count+' tk.ID,標準答案 from 題庫表 tk where id in '+Result

else

Result := ' select top '+t_count+' tk.ID,標準答案 from 題庫表 tk where 1=1 ';

end;

//以下為調(diào)用上述函數(shù)生成隨機抽題的代碼片斷

.......

with tk_query do

begin

Close;

sql.Clear;

sql.Text := Get_Random_Sql(Kcdm,tx_str,zsd_str,nyd_str,txzsd_count_str);

Open;

end;

本文最后更新于 2023-3-16 16:46,某些文章具有時效性,若有錯誤或已失效,請在網(wǎng)站留言或聯(lián)系站長:[email protected]
·END·
站長網(wǎng)微信號:w17tui,關(guān)注站長、創(chuàng)業(yè)、關(guān)注互聯(lián)網(wǎng)人 - 互聯(lián)網(wǎng)創(chuàng)業(yè)者營銷服務(wù)中心

免責(zé)聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡(luò)收集,旨在傳播知識,文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請勿用于商業(yè)用途,如果損害了您的權(quán)利,請聯(lián)系我們及時修正或刪除。謝謝!

17站長網(wǎng)微信二維碼

始終以前瞻性的眼光聚焦站長、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領(lǐng)域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長轉(zhuǎn)型升級,為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質(zhì)的創(chuàng)業(yè)信息和品牌營銷服務(wù),與站長一起進步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨!

掃一掃,關(guān)注站長網(wǎng)微信

大家都在看

熱門排行

最近更新

返回頂部
主站蜘蛛池模板: 精品水蜜桃久久久久久久 | 超级最爽的乱淫片免费 | 成人影院午夜久久影院 | 蜜芽丅v新网站在线观看 | 国产亚洲精品AV片在线观看播放 | 达达兔午夜一级毛片 | jizz黑丝| 国产午夜在线精品三级a午夜电影 | 把腿张开再深点好爽宝贝动态图 | 欧美激情视频在线观看一区二区三区 | 午夜DY888国产精品影院 | 韩国伦理电影在线神马网 | 亚洲精品国产高清嫩草影院 | 亚洲天码中字 | 父皇轻点插好疼H限 | 精品无码久久久久久久久 | 丁香美女社区 | 精品国产乱码久久久久久夜深人妻 | 20岁中国男同志china1069 20岁αsrian男同志免费 | 一本色道久久88综合日韩精品 | 久久久综合中文字幕久久 | 毛篇片在线观看 | 小sao货水好多真紧h的视频 | 狂操空姐电影 | 母乳女神春日もな | 日本一本在线播放 | 亚洲欧美国产综合在线 | 无人区免费一二三四乱码 | 有人有片的观看免费视频 | 亚洲 欧美 国产 综合 在线 | 国产1000部成人免费视频 | 在线播放国产视频 | 99精品成人无码A片观看金桔 | 伊人久久综在合线亚洲 | 亚洲午夜福利未满十八勿进 | 国语自产精品一区在线视频观看 | 日本熟妇乱妇熟色A片蜜桃 日本熟妇多毛XXXXX视频 | 久久人人爽人人片AV人成 | 伦理片在线线看手机版 | 国产呻吟久久久久久久92 | 高清国语自产拍免费 |