Access交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • 一本ACCESS编程方面的..
  • 再提数据库正规化之数据库的..
  • Access键盘快捷键大全..
  • Exchange 2000..
  • 几种修复ACCESS数据库..
  • 中华灯谜

最新文章

  • Access工程名称与文件..
  • Access 实现前后台数..
  • 用SSMA升迁工具移植Ac..
  • 导出Access图片控件的..
  • 同一字段中简单代替 Or ..
  • Access提示“操作或事..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > ACCESS数据库
ACCESS数据库

MS SQL Server和Access分别取得随机记录(随机抽题)之完美篇

这是博主用在一个项目上的源码片断,无论是速度、均衡性,还是随机度都非常好,当然这更不可能抽到重复记录了。

一、在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;

  注:关键就是 order by newid() 这条语句!随机因子就是从这里产生的。

二、数据库为access 2000时生成随机记录的最好办法:

 

     由于Access中没有newid()这一随机函数,故要想在Access中直接由SQL语句生成我们所希望的随机记录不太可能,因此我们只好在开发语言中生成合适SQL语句,让access执行了(博主的开发工具为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); //取得随机数

      if Result='' then

        Result := sl.Strings[ii]

      else

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

      sl.Delete(ii); //为了避免有可能出现的重复,此ID被抽取过后把它删了

      if sl.Count=0 then //如果无题可抽了退出循环

        Break;

    end;

    Result := '('+Result+')'; //给结果串前后加上(......),最终形成(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;

  //以下为调用上述函数生成随机抽题的代码片断

  .......

  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;

资料引用:http://www.knowsky.com/344605.html

发布人:佚名-www.knowsky.com/  
分享到:
点击次数:  更新时间:2008-11-13 17:15:08  【打印此页】  【关闭】
上一条:sql server与excel、access数据互导  下一条:Access数据有效性检查



相关文章

  • • Access工程名称与文件名称的区别
  • • Access 实现前后台数据库压缩
  • • 用SSMA升迁工具移植Acceses到SQL Server的几点问题
  • • 导出Access图片控件的图片到文件
  • • 同一字段中简单代替 Or 和 in 的多条件查询
  • • Access提示“操作或事件已被禁用模式阻止“解决办法
  • • 如何判断Access数据库是运行在正常完整版本(Full Access)还是运行时版本(Access Runtime)
  • • Access VBA获取U盘(优盘)机器码系列号及U盘开发的各种代码

热门文章

  • [2003-12-20] Access安全性之QA详解access数据库
  • [2008-11-15] 设定Access数据库自增长字段初始值access数据库
  • [2005-04-05] 在Access中使用系统表保存应用程序变量access数据库
  • [2009-11-30] 如何替换Access启动时的背景图片access数据库
  • [2006-10-09] 攻防实战:注水漏洞的利用和防范access数据库
  • [2005-02-10] 当Access文件大于指定的大小时就自动压缩access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn