MEJOR SITIO PARA DESARROLLADORES WEB

SQL Tutorial

SQL HOGAR SQL Introducción SQL Sintaxis SQL SELECT SQL SELECT DISTINCT SQL WHERE SQL ORDER BY SQL AND SQL OR SQL NOT SQL INSERT INTO SQL NULL Values SQL UPDATE SQL DELETE SQL SELECT TOP SQL MIN() y MAX() SQL COUNT SQL SUM SQL AVG SQL LIKE SQL Comodines SQL IN SQL BETWEEN SQL Alias SQL JOIN SQL INNER JOIN SQL LEFT JOIN SQL RIGHT JOIN SQL FULL OUTER JOIN SQL Uno mismo SQL UNION SQL GROUP BY SQL HAVING SQL EXISTS SQL ANY, ALL SQL SELECT INTO SQL INSERT INTO SELECT SQL CASE SQL NULL Funciones SQL Procedimientos almacenados SQL Comentario SQL Operadores

SQL Database

SQL CREATE DATABASE SQL DROP DATABASE SQL BACKUP DATABASE SQL CREATE TABLE SQL DROP TABLE SQL ALTER TABLE SQL Constraints SQL NOT NULL SQL UNIQUE SQL PRIMARY KEY SQL FOREIGN KEY SQL CHECK SQL DEFAULT SQL CREATE INDEX SQL AUTO INCREMENT SQL Fechas SQL CREATE VIEW SQL Inyección SQL Hosting SQL Tipos de datos

SQL Referencias

SQL Palabras clave MySQL Funciones SQL Funciones del servidor MS Access Funciones SQL Referencia rápida

SQL Ejemplos

SQL Ejemplos SQL Editor SQL Prueba SQL Ceremonias SQL Bootcamp SQL Certificado

SQL. Lecciones para principiantes

Ua En De Fr

SQL TOP, LIMIT, FETCH FIRST o ROWNUM Cláusula


La cláusula SQL SELECT TOP

La cláusula SELECT TOP se utiliza para especificar la cantidad de registros a devolver.

La cláusula SELECT TOP es útil en tablas grandes con miles de registros. Devolver una gran cantidad de registros puede afectar el rendimiento.

Ejemplo

Seleccione sólo los primeros 3 registros de la tabla Customers:

SELECT TOP 3 * FROM Customers;
Try it Yourself »

Note: Not all database systems support the SELECT TOP clause. MySQL supports the LIMIT clause to select a limited number of records, while Oracle uses FETCH FIRST n ROWS ONLY and ROWNUM.

SQL Server / MS Access Syntax:

SELECT TOP number|percent column_name(s)
FROM table_name
WHERE condition;

MySQL Syntax:

SELECT column_name(s)
FROM table_name
WHERE condition
LIMIT number;

Oracle 12 Syntax:

SELECT column_name(s)
FROM table_name
ORDER BY column_name(s)
FETCH FIRST number ROWS ONLY;

Older Oracle Syntax:

SELECT column_name(s)
FROM table_name
WHERE ROWNUM <= number;

Older Oracle Syntax (with ORDER BY):

SELECT *
FROM (SELECT column_name(s) FROM table_name ORDER BY column_name(s))
WHERE ROWNUM <= number;


Demo Database

Below is a selection from the Customers table used in the examples:

CustomerID CustomerName ContactName Address City PostalCode Country
1

Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico
4

Around the Horn Thomas Hardy 120 Hanover Sq. London WA1 1DP UK
5 Berglunds snabbköp Christina Berglund Berguvsvägen 8 Luleå S-958 22 Sweden

LIMIT

The following SQL statement shows the equivalent example for MySQL:

Ejemplo

Select the first 3 records of the Customers table:

SELECT * FROM Customers
LIMIT 3;
Try it Yourself »

FETCH FIRST

The following SQL statement shows the equivalent example for Oracle:

Ejemplo

Select the first 3 records of the Customers table:

SELECT * FROM Customers
FETCH FIRST 3 ROWS ONLY;

SQL TOP PERCENT Ejemplo

The following SQL statement selects the first 50% of the records from the "Customers" table (for SQL Server/MS Access):

Ejemplo

SELECT TOP 50 PERCENT * FROM Customers;
Try it Yourself »

The following SQL statement shows the equivalent example for Oracle:

Ejemplo

SELECT * FROM Customers
FETCH FIRST 50 PERCENT ROWS ONLY;

ADD a WHERE CLAUSE

The following SQL statement selects the first three records from the "Customers" table, where the country is "Germany" (for SQL Server/MS Access):

Ejemplo

SELECT TOP 3 * FROM Customers
WHERE Country='Germany';
Try it Yourself »

The following SQL statement shows the equivalent example for MySQL:

Ejemplo

SELECT * FROM Customers
WHERE Country='Germany'
LIMIT 3;
Try it Yourself »

The following SQL statement shows the equivalent example for Oracle:

Ejemplo

SELECT * FROM Customers
WHERE Country='Germany'
FETCH FIRST 3 ROWS ONLY;

ADD the ORDER BY Keyword

Add the ORDER BY keyword when you want to sort the result, and return the first 3 records of the sorted result.

For SQL Server and MS Access:

Ejemplo

Sort the result reverse alphabetically by CustomerName, and return the first 3 records:

SELECT TOP 3 * FROM Customers
ORDER BY CustomerName DESC;
Try it Yourself »

The following SQL statement shows the equivalent example for MySQL:

Ejemplo

SELECT * FROM Customers
ORDER BY CustomerName DESC
LIMIT 3;
Try it Yourself »

The following SQL statement shows the equivalent example for Oracle:

Ejemplo

SELECT * FROM Customers
ORDER BY CustomerName DESC
FETCH FIRST 3 ROWS ONLY;