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

数据库取前几条记录的语句

 
阅读更多

数据库取前几条记录的语句
1. ORACLE
SELECT * FROM TABLE1 WHERE ROWNUM<=N
2. INFORMIX
SELECT FIRST N * FROM TABLE1 where 1=1
3. DB2
SELECT * ROW_NUMBER() OVER(ORDER BY COL1 DESC) AS ROWNUM WHERE ROWNUM<=N
或者
SELECT COLUMN FROM TABLE where 1=1 FETCH FIRST N ROWS ONLY
4. SQL SERVER
SELECT TOP N * FROM TABLE1 where 1=1
or
SET ROWCOUNT N SELECT * FROM TABLE1 where 1=1 SET ROWCOUNT N1
5. SYBASE
SET ROWCOUNT N SELECT * FROM TABLE1 where 1=1 SET ROWCOUNT N1
6. MYSQL
SELECT * FROM TABLE1 where 1=1 LIMIT N
7. FOXPRO
SELECT * TOP N FROM TABLE ORDER BY COLUMN
8. ACCESS
SELECT TOP N * FROM TABLE1 where 1=1


 1. Oracle数据库
  
  SELECT * FROM TABLENAME WHERE ROWNUM <= N
  
  2. Infomix数据库
  
  SELECT FIRST N * FROM TABLENAME
  
  3. DB2数据库
  
  SELECT *
  FROM (SELECT * ROW_NUMBER() OVER({ORDER BY COL1 DESC}) AS ROWNUM FROM TABLENAME)
  WHERE ROWNUM <= N
  或者
  SELECT COLUMN FROM TABLENAME FETCH FIRST N ROWS ONLY
  
  4. SQL Server数据库
  
  SELECT TOP N * FROM TABLENAME
  
  5. Sybase数据库
  
  SET ROWCOUNT N
  GO
  SELECT * FROM TABLENAME
  
  6. MySQL数据库
  
  SELECT * FROM TABLENAME LIMIT N
  
  7. FoxPro数据库
  
  SELECT * TOP N FROM TABLENAME ORDER BY COLUMN
  
  
  Top关键字:
  1、首先引用一位网友出错的例子,sql="select top 30 * from data where title='"&title1&"' order by id desc"
  分析出错原因:sql语句里同时存在where和top语句的时候,并且where条件列不是合适的索引,程序执行的是全表扫描,首先是查找符合where条件的记录,而这里的top限制形同虚设。如果全表是百万级别以上的数据表,那么就这么一个简单的判断,就有可能拖垮数据库。
  2、解决办法就是去掉where条件筛选语句,如果你希望使用selcet top语句,并且还要附带where条件,那么条件中的列就得是合适的索引,如聚集索引、复合索引里的主列等,同时,where条件里也要尽量避开使用函数,or,判断NULL等会引起全部扫描的语句。这一点要记住,不然执行的是全表扫描。
  3、如何选出第N条到第2N条记录呢。这样的sql语句就可以了:
  “select top n * from TABLE_NAME where id not in (select top n id from TABLE_NAME order by id desc)"
  4、对Top基本理解下(TOP 和 SET ROWCOUNT)
  SELECT 语句中的TOP子句限制单个查询返回的行数,而SET ROWCOUNT限制所有后续查询影响的行数。在很多编程任务中这些命令提供了高效率。
  
  SET ROWCOUNT在SELECT,INSERT,UPDATE OR DELETE语句中设置可以被影响的最大行数。这些设置在命令执行时马上生效并且只影响当前的会话。为了移除这个限制执行SET ROWCOUNT 0。一些实际的任务用TOP or SET ROWCOUNT比用标准的SQL命令对编程是更有效率的。让我们在几个例子中证明:
  
  在几乎所有的数据库中最流行的一个查询是请求一个列表中的前N项。在 pubs数据库案例中,我们可以查找销售最好CD的前五项。比较用TOP,SET ROWCOUNT和使用ANSI SQL的三种方案。
  (1)Select title,ytd_salesFrom titlesa Where (select count(*)From titlesb Where b.ytd_sales>a.ytd_sales)<5 Order by ytd_sales DESC
  这个纯ANSI SQL方案执行一个效率可能很低的关联子查询,特别的在这个例子中,在ytd_sales上没有索引支持。另外,这个纯的标准SQL命令没有过滤掉在ytd_sales的空值,也没有区别多个CD间有关联的情况。
  (2)SET ROWCOUNT 5 SELECT title, ytd_salesFROM titlesORDER BY ytd_sales DESCSET ROWCOUNT 0
  (3)SELECT TOP 5 title, ytd_salesFROM titlesORDER BY ytd_sales DESC
  第二个方案使用SET ROWCOUNT来停止SELECT查询,而第三个方案是当它找到前五行时用TOP n来停止。在这种情况下,在获得结果之前我们也要有一个ORDER BY子句强制对整个表进行排序。两个查询的查询计划实际上是一样的。然而,TOP优于SET ROWCOUNT的关键点是SET必须处理ORDER BY子句所需的工作表,而TOP 不用。
  总结:在一个大表上,我们可以为表上创建一个索引以避免排序,查询将使用该索引找到前5行并停止。
  
  ROWNUM伪列:
  1、使用SELECT语句返回的结果集,希望按特定条件查询前N条记录,可以使用伪列ROWNUM。ROWNUM是对结果集加一个伪列,先查到结果集后再加上一个列,是符合条件结果的序列号;从1开始排起,只能用< > = !=这些比较符合。
  ROWNUM对于等于某值的查询条件,比如查询第一条记录,可以使用ROWNUM=1作为条件;但是如果查询第二条记录写ROWNUM=2则查询不到数据,ROWNUM的=判断只对于1有效;
  2、同理,查询大于某值的查询条件,ROWNUM>n(n>1的自然数)这种条件不成立;那如何查询第一行以后的记录呢?
  solution:用子查询解决,但是必须为rownum设置别名,"select * from (select rownum no ,id,name from table1) where no >1";
  3、ROWNUM对于小于某值的查询是可以的,select * from table1 where rownum<3
  4、ROWNUM和排序
  Oracle中rownum是在取数据时产生的序号,想对指定排序的数据指定rownum行数据就要做处理了:
  "select rownum,id,name from table1 order by name",查询结果按name排序,但是rownum不是按1、2、3...排列,而是按记录插入时的顺序给记录排号;
  solution:使用子查询,select rownum ,id,name from(select * from table1 order by name)

分享到:
评论

相关推荐

    查询前几条记录

    总之,"查询前几条记录"是数据库操作的基本技巧,涉及到SQL语句的编写和数据库性能优化。理解并熟练掌握这一技能对于任何IT开发者来说都至关重要,无论是在Web开发、数据分析还是其他领域。同时,了解数据库工具和...

    sql语句收集,常用数据库表操作语句

    - 当需要获取特定条件下前几条记录时使用。 --- #### 15. 每组最大值 **SQL语句**: ``` SELECT a, b, c FROM 表名称 ta WHERE a = (SELECT MAX(a) FROM 表名称 tb WHERE tb.b = ta.b) ``` **说明**: - 这条...

    一个进销存数据库设计的例子含SQL语句

    例如,增加一条采购订单记录: ```sql INSERT INTO PurchaseOrders (OrderID, ProductID, SupplierID, Quantity, Price, OrderDate) VALUES (1, 1, 1, 100, 10.5, '2022-01-01'); ``` 更新库存量时,可以使用...

    数据库中各种SQL语句的应用

    本文将通过具体例子来说明几种常用的SQL语句,包括`SELECT`、`INSERT`、`UPDATE`和`DELETE`等,帮助读者更好地理解和掌握这些基本的数据库操作。 #### SELECT语句 `SELECT`语句是SQL中最常用也是最重要的语句之一...

    将数据库中的数据转换成sql语句

    3. SQL语句生成:这是关键步骤,将每条数据记录转换为INSERT INTO SQL语句。每条语句包含表名和一列或多列的值,格式大致如下: ``` INSERT INTO 表名 (列1, 列2, ...) VALUES (值1, 值2, ...); ``` 4. 脚本执行...

    ABAP数据库操作之操作语句

    本文将详细介绍ABAP中几种常用的数据库操作语句,包括`INSERT`、`UPDATE`、`MODIFY`以及`DELETE`等,并通过示例代码帮助读者更好地理解和掌握这些关键概念。 #### 一、INSERT语句 **功能描述**:`INSERT`语句用于...

    数据库实验1 MYSQL数据库SQL语句练习实验.doc

    在表的定义中,需要设置主键(primary key)来唯一标识每条记录,如`DEPTNO`和`EMPNO`。主键的设置可以使用`NOT NULL`关键字来确保其值不为空。此外,外键(foreign key)的定义用于建立表之间的关联,例如`DEPTNO`...

    mysql 前几条记录语句之(limit)

    在MySQL数据库中,如果你想要获取表中的前几条记录,`LIMIT`子句是一个非常重要的工具,它在SQL查询中用于限制返回结果集的数量。在标题和描述中提到的“mysql top limit”,实际上是在指代如何用`LIMIT`来实现类似...

    全国手机号码段归属地数据库[共360569条记录]

    5. **数据结构**:数据库中的每条记录可能包含以下字段:手机号码段起始号、结束号、省份、城市、区号、邮编等。这些字段提供了丰富的信息,可以帮助用户快速定位手机号码的归属地。 6. **应用领域**: - **电信...

    组态王删除十天前的数据库信息组态王密码

    针对"组态王SQL数据库删除十天前的数据库信息"这一主题,我们可以深入探讨相关知识点。 首先,我们需要了解如何在组态王中连接和操作SQL数据库。组态王支持与多种类型的SQL数据库进行交互,如Microsoft SQL Server...

    从数据库中读取指定行数记录

    这种方法通过排除前几条记录的方式来获取所需的记录。例如,从第三条记录开始获取数据可以这样实现: ```sql SELECT * FROM table_name WHERE id_field NOT IN (SELECT TOP 3 id_field FROM table_name); ``` 这里的...

    mysql数据库介绍及常用SQLl语句(整理).pdf

    在关系型数据库中,数据以表格的形式呈现,每一行代表一条记录,每一列代表一个字段。列之间通过主键和外键关联,保证数据的完整性和一致性。例如,MySQL、Oracle、DB2和SQL Server都属于关系型数据库。而非关系型...

    【MySQL数据库】一条SQL语句为什么执行这么慢?

    【MySQL数据库】一条SQL语句执行慢的问题是一个复杂的议题,涉及到多个方面,包括数据库的内部机制、事务处理、索引优化以及SQL语句的设计。下面将深入解析导致SQL执行变慢的主要因素。 **一、执行偶尔变慢** 1. *...

    分页显示数据库记录

    例如,如果每页显示10条记录,第2页则从第11条记录开始。 2. **SQL查询**:构建带有LIMIT或OFFSET子句的SQL语句,以获取指定范围内的记录。在ACCESS中,我们使用`SELECT ... FROM ... WHERE ... ORDER BY ... LIMIT...

    达梦数据库_SQL语言手册

    修改操作的对象也可以是元组的集合,相对于面向记录的数据库语言一次只能操作一条记录来 语言的使用简化了用户的处理,提高了应用程序的运行效率 语言简洁,方便易学 语言功能强大,格式规范,表达简洁,接近英语的语法...

    2019最新ip数据库mdb,超47万条记录

    描述中提到的“47.0198万多条记录”意味着这个数据库覆盖了全球大量IP地址,几乎可以满足大部分IP查询需求。在实际应用中,这样的数据量能够提供相当广泛的IP查询覆盖范围,确保大多数用户访问时都能找到相应的地理...

    Jmeter中JDBC request多条SQL语句使用.docx

    本文将重点介绍如何在JMeter中使用JDBC Request来执行多条SQL语句,包括查询与更新操作,并针对不同类型的SQL语句提供最佳实践。 #### 二、JDBC Request概述 JDBC Request是JMeter提供的一个用于执行数据库操作的...

    几条使用率最高的SQL语句

    ### 几条使用率最高的SQL语句 在数据库管理和日常工作中,SQL(Structured Query Language,结构化查询语言)是必不可少的工具之一。SQL语言能够帮助我们有效地管理、查询和更新数据库中的数据。以下是对给定文件中...

Global site tag (gtag.js) - Google Analytics