अजगर MySQL - ऑर्डर द्वारा

SELECT क्‍वेरी का उपयोग करके डेटा लाते समय, आप ऑर्डरबीज क्‍लॉज का उपयोग करके वांछित क्रम (आरोही या अवरोही) में परिणाम सॉर्ट कर सकते हैं। डिफ़ॉल्ट रूप से, यह क्लॉज़ आरोही क्रम में परिणाम देता है, यदि आपको उन्हें अवरोही क्रम में व्यवस्थित करने की आवश्यकता है तो आपको "DESC" का स्पष्ट रूप से उपयोग करने की आवश्यकता है।

वाक्य - विन्यास

निम्नलिखित सिंटैक्स सेलेक्ट कॉलम-सूची है

FROM table_name
[WHERE condition]
[ORDER BY column1, column2,.. columnN] [ASC | DESC]; of the ORDER BY clause:

उदाहरण

मान लें कि हमने MySQL में एक तालिका बनाई है जिसका नाम EMPLOYEES है -

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)

और अगर हमने INSERT बयानों का उपयोग करते हुए इसमें 4 रिकॉर्ड डाले हैं -

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);

निम्नलिखित कथन आयु के आरोही क्रम में EMPLOYEE तालिका की सामग्री को पुनः प्राप्त करता है।

mysql> SELECT * FROM EMPLOYEE ORDER BY AGE;
+------------+-----------+------+------+--------+
| FIRST_NAME | LAST_NAME | AGE  | SEX  | INCOME |
+------------+-----------+------+------+--------+
| Krishna    | Sharma    |   19 |    M |   2000 |
| Raj        | Kandukuri |   20 |    M |   7000 |
| Ramya      | Ramapriya |   25 |    F |   5000 |
| Mac        | Mohan     |   26 |    M |   2000 |
+------------+-----------+------+------+--------+
4 rows in set (0.04 sec)

आप DESC का उपयोग करके अवरोही क्रम में डेटा पुनः प्राप्त कर सकते हैं -

mysql> SELECT * FROM EMPLOYEE ORDER BY FIRST_NAME, INCOME DESC;
+------------+-----------+------+------+--------+
| FIRST_NAME | LAST_NAME | AGE  | SEX  | INCOME |
+------------+-----------+------+------+--------+
| Krishna    | Sharma    |   19 |    M |   2000 |
| Mac        | Mohan     |   26 |    M |   2000 |
| Raj        | Kandukuri |   20 |    M |   7000 |
| Ramya      | Ramapriya |   25 |    F |   5000 |
+------------+-----------+------+------+--------+
4 rows in set (0.00 sec)

अजगर का उपयोग करके खंड द्वारा आदेश

विशिष्ट क्रम में तालिका की सामग्री प्राप्त करने के लिए, आह्वान करें execute() कर्सर ऑब्जेक्ट पर विधि और, ORDER BY क्लॉज के साथ सेलेक्ट स्टेटमेंट पास करें, इसके पैरामीटर के रूप में।

उदाहरण

निम्नलिखित उदाहरण में हम नाम और कर्मचारी के साथ एक तालिका बना रहे हैं, इसे पॉप्युलेट कर रहे हैं, और अपने रिकॉर्ड को उनकी उम्र के (आरोही) क्रम में वापस लाकर ORDER BY खंड का उपयोग कर रहे हैं।

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()

#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")
sql = '''CREATE TABLE EMPLOYEE(
   FIRST_NAME CHAR(20) NOT NULL,
   LAST_NAME CHAR(20),
   AGE INT,
   SEX CHAR(1),
   INCOME FLOAT
)'''
cursor.execute(sql)

#Populating the table
insert_stmt = "INSERT INTO EMPLOYEE (FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) 
   VALUES (%s, %s, %s, %s, %s)"

data = [('Krishna', 'Sharma', 26, 'M', 2000), 
   ('Raj', 'Kandukuri', 20, 'M', 7000),
   ('Ramya', 'Ramapriya', 29, 'F', 5000),
   ('Mac', 'Mohan', 26, 'M', 2000)]
cursor.executemany(insert_stmt, data)
conn.commit()

#Retrieving specific records using the ORDER BY clause
cursor.execute("SELECT * from EMPLOYEE ORDER BY AGE")
print(cursor.fetchall())

#Closing the connection
conn.close()

उत्पादन

[('Raj', 'Kandukuri', 20, 'M', 7000.0), 
   ('Krishna', 'Sharma', 26, 'M', 2000.0), 
   ('Mac', 'Mohan', 26, 'M', 2000.0), 
   ('Ramya', 'Ramapriya', 29, 'F', 5000.0)
]

उसी तरह आप ORDER BY क्लॉज का उपयोग करके अवरोही क्रम में एक तालिका से डेटा पुनः प्राप्त कर सकते हैं।

उदाहरण

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 specific records using the ORDERBY clause
cursor.execute("SELECT * from EMPLOYEE ORDER BY INCOME DESC")
print(cursor.fetchall())

#Closing the connection
conn.close()

उत्पादन

[('Raj', 'Kandukuri', 20, 'M', 7000.0), 
   ('Ramya', 'Ramapriya', 29, 'F', 5000.0), 
   ('Krishna', 'Sharma', 26, 'M', 2000.0), 
   ('Mac', 'Mohan', 26, 'M', 2000.0)
]