`
cuijiemin
  • 浏览: 265123 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

随机读取N条记录(MySQL、SQL Server、Access、Oracle、postgreSQL)|access

阅读更多

利用一条SQL语句从数据库Table表中随机获取N条记录,各数据库的SQL语句略有不同,如下:
1、MySql Select*From TABLE Order By Rand()Limit N
以上代码效率不高,自己对1000条数据表随机取10条的测试结果为耗时0.125s,有网友推荐改为以下代码效率有大幅提高,耗时为0.005s,不过结果是随机从某个位置开始取N条记录,而不是随机取N条记录,略有差异。详细说明见mysql使用rand随机查询记录效率测试。
SELECT*FROM`TABLE`ajoin(SELECT ROUND(RAND()*((SELECT MAX(id)FROM`TABLE`)-(SELECT MIN(id)FROM`TABLE`)) (SELECT MIN(id)FROM`TABLE`))AS id)AS bWHERE a.id=b.idORDER BY a.id LIMIT N;
2、SQL Server Select TOP N*From TABLE Order By NewID()NewID()函数将创建一个uniqueidentifier类型的唯一值。
3、Access Select TOP N*From TABLE Order By Rnd(ID)
Rnd(ID)其中的ID是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段(UserName)
Select TOP N*From TABLE Order BY Rnd(Len(UserName))
4、Oracle 1)dbms_random包
select*from(select*from Table order by dbms_random.value)where rownum N;
注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql dbms_random.value(100,200)
可以产生100到200范围的随机数
2)按概率抽取:
select*from Table sample(百分比);例:
select*from Table sample(10);取表Table中记录条数的10%条记录
3)sys_guid select*from(select*from Tableorderby sys_guid())whererownum N;
5、postgreSQL select*from Table order by random()limit N

分享到:
评论
2 楼 cuijiemin 2012-09-05  
sbpya 写道
捷敏同学,有缘啊,今天搜PG的这个语句时,跑到你的博客里来了,呵呵!

你好,你是?
1 楼 sbpya 2012-04-20  
捷敏同学,有缘啊,今天搜PG的这个语句时,跑到你的博客里来了,呵呵!

相关推荐

    access数据库转换工具

    Access数据库(.mdb或.accdb)虽然在小型企业和个人用户中广泛应用,但有时需要与不支持Access格式的系统集成,例如SQL Server、MySQL、Oracle,或者需要将数据导出为CSV、XML等通用格式。在这种情况下,转换工具就...

    如何从数据库中随机取出10条记录的方法

    ### 如何从数据库中随机取出10条记录的方法 在处理大量数据时,有时我们需要从数据库中随机抽取一部分记录来进行数据分析、测试或者展示等操作。本文将详细介绍如何从数据库中随机取出10条记录的方法,并提供多种...

    Kettle所有数据库数据库连接驱动Jar

    除此之外,这个压缩包可能还包括了其他数据库的驱动,如Oracle的`ojdbc.jar`,PostgreSQL的`postgresql.jar`,IBM DB2的`db2jcc.jar`,以及SQLite的`sqlite-jdbc.jar`等。这些驱动使得Kettle能够无缝地与不同类型的...

    根据数据库导出SQL语句

    例如,从ACCESS转到MySQL、PostgreSQL或Oracle等,都需要将数据转换成这些系统能够理解的SQL格式。 标签“导出SQL语句”进一步明确了这个工具的主要功能,即它是一个用于创建SQL脚本的实用程序,专门针对ACCESS...

    JAVA连接ACCESS数据库文件(.mdb/.accdb)所需的jar包

    在Java编程中,连接Microsoft Access数据库(通常以.mdb或.accdb文件格式存在)需要特定的库...不过,考虑到性能和扩展性,对于大型企业级应用,更推荐使用支持JDBC的其他数据库系统,如MySQL、PostgreSQL或Oracle。

    LINUX平台JAVA直接连接access数据库dbf文件

    因此,这种方法可能不适合大规模的生产环境,更推荐在Windows环境下使用Access,或者将数据迁移到更适应LINUX的数据库系统,如MySQL或PostgreSQL。 通过以上步骤,你可以在LINUX平台上使用Java连接并操作Access...

    java连接各种数据库DEMO

    ### Java连接各种数据库示例详解 ...以上就是关于Java连接Oracle、SQL Server、MySQL、PostgreSQL和Access数据库的基本方法和示例代码。这些示例涵盖了从加载驱动到处理结果集的全过程,希望对您有所帮助。

    Hibernate中使用Access

    然而,通常情况下,Hibernate与诸如MySQL、Oracle或PostgreSQL等大型关系型数据库配合使用,而较少与Microsoft Access这样的小型数据库系统结合。尽管如此,对于一些小型项目或者学习目的,使用Hibernate与Access...

    java 连接各种数据库的字符串

    本文将详细介绍如何使用Java连接常见的几种数据库(包括Oracle、DB2、SQL Server、Sybase、Informix、MySQL、PostgreSQL和Access),并提供具体的代码示例。 #### 1. Oracle数据库连接 Oracle是一种广泛使用的商业...

    SQL - 快速指南SQL - Quick Guide

    它是关系型数据库管理系统的基础语言,几乎所有主流的关系型数据库管理系统(RDBMS)都支持SQL,包括MySQL、Microsoft Access、Oracle、Sybase、Informix、PostgreSQL和SQL Server等。尽管它们都遵循SQL标准,但不同...

    基于Java的Access数据库操作库Jackcess.zip

    Java编程语言以其跨平台性和广泛的应用领域而闻名,而在处理数据存储方面,它通常与关系型数据库管理系统(RDBMS)如MySQL、Oracle或PostgreSQL等进行集成。然而,对于那些需要与Microsoft Access数据库交互的Java...

    java与Access 数据库连接访问表 例子

    在IT行业中,数据库是存储和管理数据的核心工具,而Java作为一种...同时,随着技术的发展,对于大型项目,可能会转向如MySQL、Oracle、PostgreSQL等更强大的数据库系统,而Java依然能作为连接这些数据库的强大工具。

    DataAccess

    常见的数据库系统包括MySQL、Oracle、SQL Server、PostgreSQL等。 2. **API和库**: 在不同的编程语言中,有许多API和库用于处理`DataAccess`。例如,Java有JDBC(Java Database Connectivity),Python有PyODBC、...

    Telerik Data Access 2015.1 225 (Feb 25, 2015)

    该产品提供了强大的ORM(对象关系映射)功能,支持多种数据库类型,包括SQL Server、Oracle、MySQL等,并且具备出色的性能优化能力,能够显著提升应用程序的数据处理速度。 ### 二、2015.1 225版本特性 由于具体...

    八种数据库的连接方式

    本文将详细介绍八种常见数据库的连接方式,包括Oracle、DB2、SqlServer、Sybase、Informix、MySQL、PostgreSQL以及Access数据库,帮助开发者更好地理解和掌握数据库连接的技术细节。 ### 1. Oracle8/8i/9i数据库...

    Access工具

    它提供了一个统一的API来访问各种数据库,如MySQL、Oracle、SQL Server、PostgreSQL以及我们的目标——Access。FireDAC支持异步执行、数据流模式、事务处理,以及广泛的参数化查询,使得在没有Access软件的情况下,...

    oracle otl 文档

    它的设计目的是提供一个高效、灵活且跨平台的解决方案,支持包括Oracle、MS SQL Server、Sybase、Informix、MySQL、DB2、Interbase/Firebird、PostgreSQL、SQLite、SAP/DB、TimesTen、MS ACCESS等多种主流数据库系统...

    数据库助手

    数据库助手支持多种SQL数据库,包括但不限于SQL Server、MySQL、PostgreSQL等。用户可以执行SQL查询、更新、插入和删除操作,也可以创建和管理数据库对象,如表、视图、索引和存储过程。 4. **MYSQL数据库管理**: ...

    sql map用户手册.docx

    sqlmap 支持多种不同的数据库管理系统,包括 MySQL、Oracle、PostgreSQL、Microsoft SQL Server、Microsoft Access、IBM DB2、SQLite、Firebird 和 Sybase 等。 使用 sqlmap,可以自动检测 Web 应用程序中的 SQL ...

    C#与各数据库连接信息

    下面将详细介绍C#与常见数据库(如MySQL、SQL Server、Oracle、SQLite和PostgreSQL)的连接知识点。 1. **C#与SQL Server数据库连接** - 使用ADO.NET框架,通过SqlConnection类建立连接。例如: ```csharp using...

Global site tag (gtag.js) - Google Analytics