首页 - 数据库 - SQL Server

四种数据库,取随机记录的方法

发布时间: 2007-04-19 05:04    作者: 未知    来源: 未知    浏览:    评论


mysql:select * from tablename order by rand() limit 10sqlserver:select top 10 * from tablename order by NEWID()

ORACLE:使用 dbms random value的一种方法


SQL> select *from (select *from t order by dbms_random.value) where rownum<10;

         A ----------         39        101        134          5         83         97         96        140         81

已选择9行。

SQL> select *from (select *from t order by dbms_random.value) where rownum<10;

         A ----------         27        118        141        103        128         10        142         68         74  有人说这是一种效率最差的方法,恳请告知比这更好的解决方案!

ACCESS(一):
yourstr="*1*3*4*6*12*...."sql="select top 10 * form yourdb where instr('*'&id&'*','"&yourstr&"')<>0
ACCESS(二):
<%   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%>



SQL> select *from (select *from t order by dbms_random.value) where rownum<10;

         A ----------         39        101        134          5         83         97         96        140         81

已选择9行。

SQL> select *from (select *from t order by dbms_random.value) where rownum<10;

         A ----------         27        118        141        103        128         10        142         68         74  有人说这是一种效率最差的方法,恳请告知比这更好的解决方案!

ACCESS(一):
yourstr="*1*3*4*6*12*...."sql="select top 10 * form yourdb where instr('*'&id&'*','"&yourstr&"')<>0
ACCESS(二):
<%   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%>

TAG

Smile Big Smile Surprise Stick out tongue Wink Sad Tongue Tied Indifferent Crying Embarrassed Cool Angry Angel Devil [8-|] [:#] [:-*] [:^)] [<:o)] [|-)] Yes Beer Left Hug Music Star Time Snail Pizza Automobile Umbrella Computer Storm [mo] [8o|] [^o)] [+o(] [*-)] [8-)] Coffee No Drinks [Z] Right Hug Cake Broken Heart Gift Wilted Flower Movie Dog Idea Sleep Email Travel Paradise
呢称:

加粗 斜体 下划线 链接 图片 代码 邮件地址 引用 列表

最多只能输入100个字符

Tags

SQL 数据库 asp.net C# XML 控件 .NET教程 程序 事件 数据 安全 代码 Server 客户端 验证 数据库专栏 接口 文件 Oracle DataSet 函数 DataGrid 问题 .net return C#语言 JavaScript 服务 IIS 对象 语句 windows 继承 时间 web.config 设计 开发 参数 变量 解决 字符 ADO.net 环境 VB.Net语言 web 异常 工具 服务器 计算 实例 OLEDB Application VB Word WebService insert asp net 安装 记录

精华推荐

更多

精品下载

更多