Python MySQL - Limite

Lors de la récupération des enregistrements si vous souhaitez les limiter par un nombre particulier, vous pouvez le faire en utilisant la clause LIMIT de MYSQL.

Exemple

Supposons que nous ayons créé une table dans MySQL avec le nom EMPLOYEES comme -

mysql> CREATE TABLE EMPLOYEE(
   FIRST_NAME CHAR(20) NOT NULL,
   LAST_NAME CHAR(20),
   AGE INT,
   SEX CHAR(1),
   INCOME FLOAT
);
Query OK, 0 rows affected (0.36 sec)

Et si nous y avons inséré 4 enregistrements en utilisant des instructions INSERT comme -

mysql> INSERT INTO EMPLOYEE VALUES
   ('Krishna', 'Sharma', 19, 'M', 2000),
   ('Raj', 'Kandukuri', 20, 'M', 7000),
   ('Ramya', 'Ramapriya', 25, 'F', 5000),
   ('Mac', 'Mohan', 26, 'M', 2000);

L'instruction SQL suivante récupère les deux premiers enregistrements de la table Employee à l'aide de la clause LIMIT.

SELECT * FROM EMPLOYEE LIMIT 2;
+------------+-----------+------+------+--------+
| FIRST_NAME | LAST_NAME | AGE  | SEX  | INCOME |
+------------+-----------+------+------+--------+
| Krishna    | Sharma    |    19| M    | 2000   |
| Raj        | Kandukuri |    20| M    | 7000   |
+------------+-----------+------+------+--------+
2 rows in set (0.00 sec)

Clause de limite à l'aide de Python

Si vous invoquez le execute() sur l'objet curseur en passant la requête SELECT avec la clause LIMIT, vous pouvez récupérer le nombre requis d'enregistrements.

Exemple

L'exemple python suivant crée et remplit une table avec le nom EMPLOYEE et, à l'aide de la clause LIMIT, il récupère les deux premiers enregistrements de celle-ci.

import mysql.connector
#establishing the connection
conn = mysql.connector.connect(
   user='root', password='password', host='127.0.0.1', database='mydb'
)

#Creating a cursor object using the cursor() method
cursor = conn.cursor()

#Retrieving single row
sql = '''SELECT * from EMPLOYEE LIMIT 2'''

#Executing the query
cursor.execute(sql)

#Fetching the data
result = cursor.fetchall();
print(result)

#Closing the connection
conn.close()

Production

[('Krishna', 'Sharma', 26, 'M', 2000.0), ('Raj', 'Kandukuri', 20, 'M', 7000.0)]

LIMIT avec OFFSET

Si vous avez besoin de limiter les enregistrements à partir du nième enregistrement (et non du 1er), vous pouvez le faire, en utilisant OFFSET avec LIMIT.

Example

import mysql.connector
#establishing the connection
conn = mysql.connector.connect(
   user='root', password='password', host='127.0.0.1', database='mydb'
)

#Creating a cursor object using the cursor() method
cursor = conn.cursor()

#Retrieving single row
sql = '''SELECT * from EMPLOYEE LIMIT 2 OFFSET 2'''

#Executing the query
cursor.execute(sql)

#Fetching the data
result = cursor.fetchall();
print(result)

#Closing the connection
conn.close()

Output

[('Ramya', 'Ramapriya', 29, 'F', 5000.0), ('Mac', 'Mohan', 26, 'M', 2000.0)]