पायथन SQLite - जहां खंड

यदि आप SQLite में तालिका की विशेष पंक्तियों को लाना, हटाना या अपडेट करना चाहते हैं, तो आपको ऑपरेशन के लिए तालिका की पंक्तियों को फ़िल्टर करने के लिए शर्त निर्दिष्ट करने के लिए जहां क्लॉज का उपयोग करना होगा।

उदाहरण के लिए, यदि आपके पास खंड के साथ एक सेलेक्ट स्टेटमेंट है, तो केवल पंक्तियाँ जो निर्दिष्ट स्थिति को संतुष्ट करती हैं, को पुनः प्राप्त किया जाएगा।

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

SQLite में WHERE क्लॉज का वाक्य विन्यास निम्नलिखित है -

SELECT column1, column2, columnN
FROM table_name
WHERE [search_condition]

आप तुलना या तार्किक ऑपरेटरों का उपयोग करके एक search_condition निर्दिष्ट कर सकते हैं। जैसे>, <, =, LIKE, NOT, आदि निम्नलिखित उदाहरण इस अवधारणा को स्पष्ट करेंगे।

उदाहरण

मान लें कि हमने निम्नलिखित क्वेरी का उपयोग करके CRICKETERS नाम के साथ एक तालिका बनाई है -

sqlite> CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255),
   Last_Name VARCHAR(255),
   Age int,
   Place_Of_Birth VARCHAR(255),
   Country VARCHAR(255)
);
sqlite>

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

sqlite> insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
sqlite> insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
sqlite> insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
sqlite> insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
sqlite>

चयन विवरण के बाद उन अभिलेखों को पुनः प्राप्त किया जाता है जिनकी आयु 35 से अधिक है -

sqlite> SELECT * FROM CRICKETERS WHERE AGE > 35;
First_Name Last_Name  Age  Place_Of_B Country
---------- ---------- ---- ---------- -------------
Jonathan   Trott      38   CapeTown   SouthAfrica
Kumara     Sangakkara 41   Matale     Srilanka
sqlite>

जहां अजगर का उपयोग कर खंड

Cursor ऑब्जेक्ट / क्लास में क्वेरीज़ को निष्पादित करने और डेटा को लाने के लिए सभी तरीके हैं, आदि कनेक्शन क्लास का कर्सर विधि एक कर्सर ऑब्जेक्ट देता है।

इसलिए, अजगर का उपयोग कर SQLite डेटाबेस में एक तालिका बनाने के लिए -

  • कनेक्ट () विधि का उपयोग करके डेटाबेस के साथ संबंध स्थापित करें।

  • उपरोक्त बनाई गई कनेक्शन ऑब्जेक्ट पर कर्सर () विधि को लागू करके एक कर्सर ऑब्जेक्ट बनाएं।

  • अब Cursor वर्ग के निष्पादन () पद्धति का उपयोग करके क्रिएट टेबल स्टेटमेंट को निष्पादित करें।

उदाहरण

उदाहरण के बाद कर्मचारी नाम की एक तालिका बनाता है और उसे पॉप्युलेट करता है। फिर जहां क्लॉज का उपयोग करते हुए यह 23 से कम आयु मान के साथ रिकॉर्ड प्राप्त करता है।

import sqlite3

#Connecting to sqlite
conn = sqlite3.connect('example.db')

#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
cursor.execute('''INSERT INTO EMPLOYEE(
   FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES 
   ('Ramya', 'Rama priya', 27, 'F', 9000)''')

cursor.execute('''INSERT INTO EMPLOYEE
   (FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES 
   ('Vinay', 'Battacharya', 20, 'M', 6000)''')

cursor.execute('''INSERT INTO EMPLOYEE(
   FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES 
   ('Sharukh', 'Sheik', 25, 'M', 8300)''')

cursor.execute('''INSERT INTO EMPLOYEE(
   FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES 
   ('Sarmista', 'Sharma', 26, 'F', 10000)''')

cursor.execute('''INSERT INTO EMPLOYEE(
   FIRST_NAME, LAST_NAME, AGE, SEX, INCOME) VALUES 
   ('Tripthi', 'Mishra', 24, 'F', 6000)''')

#Retrieving specific records using the where clause
cursor.execute("SELECT * from EMPLOYEE WHERE AGE <23")
print(cursor.fetchall())

#Commit your changes in the database
conn.commit()

#Closing the connection
conn.close()

उत्पादन

[('Vinay', 'Battacharya', 20, 'M', 6000.0)]