पायथन पोस्टग्रेक्सेल - त्वरित गाइड

PostgreSQL एक शक्तिशाली, ओपन सोर्स ऑब्जेक्ट-रिलेशनल डेटाबेस सिस्टम है। इसमें 15 वर्षों से अधिक सक्रिय विकास चरण और एक सिद्ध वास्तुकला है जिसने इसे विश्वसनीयता, डेटा अखंडता और शुद्धता के लिए एक मजबूत प्रतिष्ठा अर्जित की है।

अजगर का उपयोग करके PostgreSQL के साथ संवाद करने के लिए आपको साइकोपग स्थापित करने की आवश्यकता है, अजगर प्रोग्रामिंग के लिए प्रदान किया गया एक एडेप्टर, इस का वर्तमान संस्करण है psycog2

psycopg2 को बहुत छोटा और तेज, और चट्टान के रूप में स्थिर होने के उद्देश्य से लिखा गया था। यह पीआईपी (अजगर के पैकेज मैनेजर) के तहत उपलब्ध है

पीआईपी का उपयोग करके Psycog2 को स्थापित करना

सबसे पहले, सुनिश्चित करें कि अजगर और पीआईपी आपके सिस्टम में ठीक से स्थापित है और, पीआईपी अप-टू-डेट है।

पीआईपी को अपग्रेड करने के लिए, कमांड प्रॉम्प्ट खोलें और निम्न कमांड निष्पादित करें -

C:\Users\Tutorialspoint>python -m pip install --upgrade pip
Collecting pip
   Using cached 
https://files.pythonhosted.org/packages/8d/07/f7d7ced2f97ca3098c16565efbe6b15fafcba53e8d9bdb431e09140514b0/pip-19.2.2-py2.py3-none-any.whl
Installing collected packages: pip
   Found existing installation: pip 19.0.3
      Uninstalling pip-19.0.3:
         Successfully uninstalled pip-19.0.3
Successfully installed pip-19.2.2

फिर, व्यवस्थापक मोड में कमांड प्रॉम्प्ट खोलें और निष्पादित करें pip install psycopg2-binary नीचे दिखाए अनुसार कमांड -

C:\WINDOWS\system32>pip install psycopg2-binary
Collecting psycopg2-binary
   Using cached 
https://files.pythonhosted.org/packages/80/79/d0d13ce4c2f1addf4786f4a2ded802c2df66ddf3c1b1a982ed8d4cb9fc6d/psycopg2_binary-2.8.3-cp37-cp37m-win32.whl
Installing collected packages: psycopg2-binary
Successfully installed psycopg2-binary-2.8.3

सत्यापन

स्थापना को सत्यापित करने के लिए, इसमें निम्न पंक्ति के साथ एक नमूना अजगर स्क्रिप्ट बनाएं।

import mysql.connector

यदि इंस्टॉलेशन सफल है, जब आप इसे निष्पादित करते हैं, तो आपको कोई त्रुटि नहीं मिलनी चाहिए -

D:\Python_PostgreSQL>import psycopg2
D:\Python_PostgreSQL>

PostgreSQL प्रश्नों को निष्पादित करने के लिए अपना स्वयं का शेल प्रदान करता है। PostgreSQL डेटाबेस के साथ संबंध स्थापित करने के लिए, सुनिश्चित करें कि आपने इसे अपने सिस्टम में ठीक से स्थापित किया है। PostgreSQL शेल प्रॉम्प्ट खोलें और सर्वर, डेटाबेस, उपयोगकर्ता नाम और पासवर्ड जैसे विवरण पास करें। यदि आपके द्वारा दिए गए सभी विवरण उपयुक्त हैं, तो एक कनेक्शन PostgreSQL डेटाबेस के साथ स्थापित किया गया है।

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

पायथन का उपयोग करके कनेक्शन स्थापित करना

का कनेक्शन वर्ग psycopg2किसी कनेक्शन की आवृत्ति का प्रतिनिधित्व / संभालता है। आप का उपयोग करके नए कनेक्शन बना सकते हैंconnect()समारोह। यह मूलभूत कनेक्शन पैरामीटर जैसे dbname, उपयोगकर्ता, पासवर्ड, होस्ट, पोर्ट को स्वीकार करता है और कनेक्शन ऑब्जेक्ट लौटाता है। इस फ़ंक्शन का उपयोग करके, आप PostgreSQL के साथ एक कनेक्शन स्थापित कर सकते हैं।

उदाहरण

निम्न पायथन कोड दिखाता है कि मौजूदा डेटाबेस से कैसे कनेक्ट किया जाए। यदि डेटाबेस मौजूद नहीं है, तो इसे बनाया जाएगा और अंत में एक डेटाबेस ऑब्जेक्ट वापस कर दिया जाएगा। PostgreSQL के डिफ़ॉल्ट डेटाबेस का नाम Postrgre है। इसलिए, हम इसे डेटाबेस नाम के रूप में आपूर्ति कर रहे हैं।

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="postgres", user='postgres', password='password', 
   host='127.0.0.1', port= '5432'
)

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

#Executing an MYSQL function using the execute() method
cursor.execute("select version()")

#Fetch a single row using fetchone() method.
data = cursor.fetchone()
print("Connection established to: ",data)

#Closing the connection
conn.close()
Connection established to: (
   'PostgreSQL 11.5, compiled by Visual C++ build 1914, 64-bit',
)

उत्पादन

Connection established to: (
   'PostgreSQL 11.5, compiled by Visual C++ build 1914, 64-bit',
)

आप CREATE DATABASE स्टेटमेंट का उपयोग करके PostgreSQL में एक डेटाबेस बना सकते हैं। आप कमांड के बाद बनाए जाने वाले डेटाबेस के नाम को निर्दिष्ट करके पोस्टग्रेएसक्यूएल शेल प्रॉम्प्ट में इस कथन को निष्पादित कर सकते हैं।

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

इसके बाद CREAT DATABASE स्टेटमेंट का सिंटैक्स है।

CREATE DATABASE dbname;

उदाहरण

निम्न कथन PostgreSQL में testdb नाम का एक डेटाबेस बनाता है।

postgres=# CREATE DATABASE testdb;
CREATE DATABASE

आप \ l कमांड का उपयोग करके डेटाबेस को PostgreSQL में सूचीबद्ध कर सकते हैं। यदि आप डेटाबेस की सूची को सत्यापित करते हैं, तो आप नए बनाए गए डेटाबेस को निम्नानुसार पा सकते हैं -

postgres=# \l
                                                List of databases
   Name    | Owner    | Encoding |        Collate             |     Ctype   |
-----------+----------+----------+----------------------------+-------------+
mydb       | postgres | UTF8     | English_United States.1252 | ........... |
postgres   | postgres | UTF8     | English_United States.1252 | ........... |
template0  | postgres | UTF8     | English_United States.1252 | ........... |
template1  | postgres | UTF8     | English_United States.1252 | ........... |
testdb     | postgres | UTF8     | English_United States.1252 | ........... |
(5 rows)

आप कमांड क्राइब का उपयोग करके कमांड प्रॉम्प्ट से एक पोस्टग्रेएसक्यूएल में एक डेटाबेस भी बना सकते हैं , एसक्यूएल स्टेटमेंट क्रिएट डेटा के आसपास एक आवरण।

C:\Program Files\PostgreSQL\11\bin> createdb -h localhost -p 5432 -U postgres sampledb
Password:

पायथन का उपयोग कर एक डेटाबेस बनाना

Psycopg2 का कर्सर वर्ग विभिन्न पोस्टग्रेक्यूएल कमांड, विभिन्न रिकॉर्ड और कॉपी डेटा को निष्पादित करने के लिए विभिन्न तरीके प्रदान करता है। आप कनेक्शन वर्ग के कर्सर () पद्धति का उपयोग करके एक कर्सर ऑब्जेक्ट बना सकते हैं।

इस वर्ग का निष्पादन () विधि एक PostgreSQL क्वेरी को एक पैरामीटर के रूप में स्वीकार करता है और इसे निष्पादित करता है।

इसलिए, PostgreSQL में एक डेटाबेस बनाने के लिए, इस पद्धति का उपयोग करके क्रिएट डटैबे क्वेरी को निष्पादित करें।

उदाहरण

अजगर उदाहरण के बाद PostgreSQL डेटाबेस में mydb नाम का एक डेटाबेस बनाता है।

import psycopg2

#establishing the connection

conn = psycopg2.connect(
   database="postgres", user='postgres', password='password', 
   host='127.0.0.1', port= '5432'
)
conn.autocommit = True

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

#Preparing query to create a database
sql = '''CREATE database mydb''';

#Creating a database
cursor.execute(sql)
print("Database created successfully........")

#Closing the connection
conn.close()

उत्पादन

Database created successfully........

आप क्रिएट टेबल स्टेटमेंट का उपयोग करके PostgreSQL के डेटाबेस में एक नई तालिका बना सकते हैं। इसे निष्पादित करते समय आपको तालिका का नाम, कॉलम के नाम और उनके डेटा प्रकार निर्दिष्ट करने की आवश्यकता होती है।

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

PostgreSQL में CREATE TABLE स्टेटमेंट का सिंटैक्स निम्नलिखित है।

CREATE TABLE table_name(
   column1 datatype,
   column2 datatype,
   column3 datatype,
   .....
   columnN datatype,
);

उदाहरण

उदाहरण के बाद PostgreSQL में CRICKETERS नाम से एक तालिका बनाता है।

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255),
   Last_Name VARCHAR(255),
   Age INT,
   Place_Of_Birth VARCHAR(255),
   Country VARCHAR(255));
CREATE TABLE
postgres=#

आप PostgreSQL में डेटाबेस में तालिकाओं की सूची \ dt कमांड का उपयोग करके प्राप्त कर सकते हैं। एक तालिका बनाने के बाद, यदि आप तालिकाओं की सूची को सत्यापित कर सकते हैं, तो आप इसमें नई बनाई गई तालिका का निरीक्षण कर सकते हैं -

postgres=# \dt
         List of relations
Schema  | Name       | Type  | Owner
--------+------------+-------+----------
public  | cricketers | table | postgres
(1 row)
postgres=#

उसी तरह, आप नीचे दिखाए गए अनुसार \ d का उपयोग करके बनाई गई तालिका का विवरण प्राप्त कर सकते हैं -

postgres=# \d cricketers
                        Table "public.cricketers"
Column          | Type                   | Collation | Nullable | Default
----------------+------------------------+-----------+----------+---------
first_name      | character varying(255) |           |          |
last_name       | character varying(255) |           |          |
age             | integer                |           |          |
place_of_birth  | character varying(255) |           |          |
country         | character varying(255) |           |          |

postgres=#

पायथन का उपयोग करके एक तालिका बनाना

अजगर का उपयोग कर एक तालिका बनाने के लिए आपको pyscopg2 के कर्सर के निष्पादन () विधि का उपयोग करके क्रिएट टेबल स्टेटमेंट को निष्पादित करना होगा

उदाहरण

निम्नलिखित पायथन उदाहरण नाम कर्मचारी के साथ एक तालिका बनाता है।

import psycopg2

#Establishing the connection

conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

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

#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")

#Creating table as per requirement
sql ='''CREATE TABLE EMPLOYEE(
   FIRST_NAME CHAR(20) NOT NULL,
   LAST_NAME CHAR(20),
   AGE INT,
   SEX CHAR(1),
   INCOME FLOAT)'''
cursor.execute(sql)
print("Table created successfully........")

#Closing the connection
conn.close()

उत्पादन

Table created successfully........

आप का उपयोग कर PostgreSQL में एक मौजूदा तालिका में रिकॉर्ड सम्मिलित कर सकते हैं INSERT INTOबयान। इसे निष्पादित करते समय, आपको तालिका का नाम, और इसमें स्तंभों के लिए मान निर्दिष्ट करने की आवश्यकता होती है।

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

निम्नलिखित INSERT बयान की सिफारिश की वाक्य रचना है -

INSERT INTO TABLE_NAME (column1, column2, column3,...columnN)
VALUES (value1, value2, value3,...valueN);

जहां, column1, column2, column3, .. एक तालिका के कॉलम के नाम हैं, और value1, value2, value3, ... वे मान हैं जिन्हें आपको तालिका में सम्मिलित करने की आवश्यकता है।

उदाहरण

मान लें कि हमने नीचे दिखाए गए अनुसार क्रेट टेबल स्टेटमेंट का उपयोग करके क्रिकेटर नाम से एक टेबल बनाई है -

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255),
   Last_Name VARCHAR(255),
   Age INT,
   Place_Of_Birth VARCHAR(255),
   Country VARCHAR(255)
);
CREATE TABLE
postgres=#

PostgreSQL स्टेटमेंट के बाद उपरोक्त बनाई गई तालिका में एक पंक्ति सम्मिलित होती है -

postgres=# insert into CRICKETERS 
   (First_Name, Last_Name, Age, Place_Of_Birth, Country) values
   ('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=#

INSERT INTO स्टेटमेंट का उपयोग करते हुए रिकॉर्ड सम्मिलित करते समय, यदि आप कोई कॉलम नाम छोड़ते हैं, तो रिकॉर्ड उन कॉलमों में खाली स्थान छोड़कर डाला जाएगा, जिन्हें आपने छोड़ दिया है।

postgres=# insert into CRICKETERS 
   (First_Name, Last_Name, Country) values('Jonathan', 'Trott', 'SouthAfrica');
INSERT 0 1

आप स्तंभ नामों को निर्दिष्ट किए बिना तालिका में रिकॉर्ड भी डाल सकते हैं, यदि आपके द्वारा पारित मानों का क्रम तालिका में उनके संबंधित स्तंभ नामों के समान है।

postgres=# insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1
postgres=#

अभिलेखों को एक तालिका में सम्मिलित करने के बाद आप नीचे दिखाए गए कथन के अनुसार इसकी सामग्री को सत्यापित कर सकते हैं -

postgres=# SELECT * from CRICKETERS;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Shikhar     | Dhawan     | 33  | Delhi          | India
Jonathan    | Trott      |     |                | SouthAfrica
Kumara      | Sangakkara | 41  | Matale         | Srilanka
Virat       | Kohli      | 30  | Delhi          | India
Rohit       | Sharma     | 32  | Nagpur         | India
(5 rows)

पायथन का उपयोग करके डेटा सम्मिलित करना

Psycopg2 का कर्सर वर्ग नाम निष्पादित () विधि के साथ एक विधि प्रदान करता है। यह विधि क्वेरी को एक पैरामीटर के रूप में स्वीकार करती है और इसे निष्पादित करती है।

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

  • आयात psycopg2 पैकेज।

  • का उपयोग कर एक कनेक्शन ऑब्जेक्ट बनाएँ connect() विधि, उपयोगकर्ता नाम, पासवर्ड, होस्ट (वैकल्पिक डिफ़ॉल्ट: लोकलहोस्ट) और, डेटाबेस (वैकल्पिक) को मापदंडों के रूप में पारित करके।

  • विशेषता के मान के रूप में गलत सेट करके ऑटो-कम मोड को बंद करें autocommit

  • cursor() की विधि Connectionpsycopg2 लाइब्रेरी का क्लास एक कर्सर ऑब्जेक्ट देता है। इस विधि का उपयोग करके एक कर्सर ऑब्जेक्ट बनाएं।

  • फिर, INSERT स्टेटमेंट को निष्पादित करने के लिए एक पैरामीटर के रूप में / उन्हें पास करके निष्पादित करें।

उदाहरण

पायथन कार्यक्रम के बाद PostgreSQL डेटाबेस में EMPLOYEE के नाम के साथ एक तालिका बनाता है और इसे निष्पादित () विधि का उपयोग करके रिकॉर्ड सम्मिलित करता है -

import psycopg2

#Establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

# Preparing SQL queries to INSERT a record into the database.
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)''')

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

print("Records inserted........")

# Closing the connection
conn.close()

उत्पादन

Records inserted........

आप पोस्टग्रे SQL में मौजूदा तालिका की सामग्री को SELECT स्टेटमेंट का उपयोग करके पुनः प्राप्त कर सकते हैं। इस कथन पर, आपको तालिका का नाम निर्दिष्ट करने की आवश्यकता है और, यह अपनी सामग्री को सारणीबद्ध प्रारूप में लौटाता है जिसे परिणाम सेट के रूप में जाना जाता है।

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

PostgreSQL में SELECT स्टेटमेंट का सिंटैक्स निम्नलिखित है -

SELECT column1, column2, columnN FROM table_name;

उदाहरण

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

postgres=# CREATE TABLE CRICKETERS ( 
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);

CREATE TABLE

postgres=#

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

postgres=# insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1

सेलेक्ट क्वेरी के बाद कॉलम FIRST_NAME, LAST_NAME और, CRICKETERS तालिका से COUNTRY का मान प्राप्त करता है।

postgres=# SELECT FIRST_NAME, LAST_NAME, COUNTRY FROM CRICKETERS;
 first_name | last_name  | country
------------+------------+-------------
Shikhar     | Dhawan     | India
Jonathan    | Trott      | SouthAfrica
Kumara      | Sangakkara | Srilanka
Virat       | Kohli      | India
Rohit       | Sharma     | India
(5 rows)

यदि आप प्रत्येक रिकॉर्ड के सभी स्तंभों को पुनः प्राप्त करना चाहते हैं, तो आपको स्तंभों के नाम "as" से बदलने की आवश्यकता है जैसा कि नीचे दिखाया गया है -

postgres=# SELECT * FROM CRICKETERS;
first_name  | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Shikhar     | Dhawan     | 33  | Delhi          | India
Jonathan    | Trott      | 38  | CapeTown       | SouthAfrica
Kumara      | Sangakkara | 41  | Matale         | Srilanka
Virat       | Kohli      | 30  | Delhi          | India
Rohit       | Sharma     | 32  | Nagpur         | India
(5 rows)

postgres=#

पायथन का उपयोग कर डेटा पुनर्प्राप्त करना

किसी भी डेटाबेस पर पढ़ें ऑपरेशन का मतलब डेटाबेस से कुछ उपयोगी जानकारी प्राप्त करना है। आप Psycopg2 द्वारा प्रदान की गई विधि () विधि का उपयोग करके PostgreSQL से डेटा प्राप्त कर सकते हैं।

Cursor वर्ग तीन तरीके प्रदान करता है जैसे कि भ्रूण (), fetchmany () और, fetchone () जहां

  • भ्रूण () विधि एक क्वेरी के परिणाम सेट में सभी पंक्तियों को पुनः प्राप्त करती है और उन्हें टुपल्स की सूची के रूप में वापस करती है। (यदि हम कुछ पंक्तियों को प्राप्त करने के बाद इसे निष्पादित करते हैं, तो यह शेष लोगों को वापस कर देता है)।

  • भ्रूण () विधि एक क्वेरी के परिणाम में अगली पंक्ति लाती है और इसे एक टुपल के रूप में वापस करती है।

Note - एक परिणाम सेट एक ऑब्जेक्ट है जिसे एक टेबल को क्वेरी करने के लिए कर्सर ऑब्जेक्ट का उपयोग करने पर वापस किया जाता है।

उदाहरण

निम्नलिखित पायथन कार्यक्रम PostgreSQL के mydb नाम के डेटाबेस से जुड़ता है और EMPLOYEE नाम की तालिका से सभी रिकॉर्ड को पुनः प्राप्त करता है।

import psycopg2

#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

#Retrieving data
cursor.execute('''SELECT * from EMPLOYEE''')

#Fetching 1st row from the table
result = cursor.fetchone();
print(result)

#Fetching 1st row from the table
result = cursor.fetchall();
print(result)

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

#Closing the connection
conn.close()

उत्पादन

('Ramya', 'Rama priya', 27, 'F', 9000.0)
[
   ('Vinay', 'Battacharya', 20, 'M', 6000.0),
   ('Sharukh', 'Sheik', 25, 'M', 8300.0),
   ('Sarmista', 'Sharma', 26, 'F', 10000.0),
   ('Tripthi', 'Mishra', 24, 'F', 6000.0)
]

SELECT, UPDATE या DELETE संचालन करते समय, आप WHERE क्लॉज का उपयोग करके रिकॉर्ड को फ़िल्टर करने के लिए शर्त निर्दिष्ट कर सकते हैं। ऑपरेशन उन अभिलेखों पर किया जाएगा जो दी गई स्थिति को संतुष्ट करते हैं।

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

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

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

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

उदाहरण

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

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#

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

postgres=# insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1

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

postgres=# SELECT * FROM CRICKETERS WHERE AGE > 35;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Jonathan    | Trott      | 38  | CapeTown       | SouthAfrica
Kumara      | Sangakkara | 41  | Matale         | Srilanka
(2 rows)

postgres=#

जहां क्लाथ पायथन का उपयोग कर रहा है

पायथन प्रोग्राम का उपयोग करते हुए एक टेबल से विशिष्ट रिकॉर्ड लाने के लिए WHERE क्लॉज के साथ SELECT स्टेटमेंट को निष्पादित करें , इसे एक पैरामीटर के रूप में पास करकेexecute() तरीका।

उदाहरण

अजगर उदाहरण के बाद अजगर का उपयोग करते हुए WHERE कमांड के उपयोग को दर्शाता है।

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

#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', 19, 'M', 2000), ('Raj', 'Kandukuri', 20, 'M', 7000),
   ('Ramya', 'Ramapriya', 25, 'M', 5000),('Mac', 'Mohan', 26, 'M', 2000)]
cursor.executemany(insert_stmt, data)

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

उत्पादन

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

आमतौर पर यदि आप किसी तालिका से डेटा पुनर्प्राप्त करने का प्रयास करते हैं, तो आपको रिकॉर्ड उसी क्रम में मिलेंगे, जिसमें आपने उन्हें सम्मिलित किया है।

का उपयोग करते हुए ORDER BY खंड, एक तालिका के रिकॉर्ड को प्राप्त करते समय आप परिणामी रिकॉर्ड को वांछित कॉलम के आधार पर आरोही या अवरोही क्रम में सॉर्ट कर सकते हैं।

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

PostgreSQL में ORDER BY क्लॉज का वाक्य विन्यास निम्नलिखित है।

SELECT column-list
FROM table_name
[WHERE condition]
[ORDER BY column1, column2, .. columnN] [ASC | DESC];

उदाहरण

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

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#

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

postgres=# insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1

चयनित चयन के बाद उनकी आयु के बढ़ते क्रम में CRICKETERS तालिका की पंक्तियों को पुनः प्राप्त किया जाता है -

postgres=# SELECT * FROM CRICKETERS ORDER BY AGE;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Virat       | Kohli      | 30  | Delhi          | India
Rohit       | Sharma     | 32  | Nagpur         | India
Shikhar     | Dhawan     | 33  | Delhi          | India
Jonathan    | Trott      | 38  | CapeTown       | SouthAfrica
Kumara      | Sangakkara | 41  | Matale         | Srilanka
(5 rows)es:

तालिका के रिकॉर्ड को सॉर्ट करने के लिए आप एक से अधिक कॉलम का उपयोग कर सकते हैं। सेलेक्ट स्टेटमेंट्स के बाद कॉलम उम्र और FIRST_NAME के ​​आधार पर CRICKETERS टेबल के रिकॉर्ड को सॉर्ट करें।

postgres=# SELECT * FROM CRICKETERS ORDER BY AGE, FIRST_NAME;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Virat       | Kohli      | 30  | Delhi          | India
Rohit       | Sharma     | 32  | Nagpur         | India
Shikhar     | Dhawan     | 33  | Delhi          | India
Jonathan    | Trott      | 38  | CapeTown       | SouthAfrica
Kumara      | Sangakkara | 41  | Matale         | Srilanka
(5 rows)

डिफ़ॉल्ट रूप से, ORDER BYखण्ड आरोही क्रम में एक तालिका के अभिलेखों को क्रमबद्ध करता है। आप DESC का उपयोग करके अवरोही क्रम में परिणामों की व्यवस्था कर सकते हैं -

postgres=# SELECT * FROM CRICKETERS ORDER BY AGE DESC;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Kumara      | Sangakkara | 41  | Matale         | Srilanka
Jonathan    | Trott      | 38  | CapeTown       | SouthAfrica
Shikhar     | Dhawan     | 33  | Delhi          | India
Rohit       | Sharma     | 32  | Nagpur         | India
Virat       | Kohli      | 30  | Delhi          | India
(5 rows)

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

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

उदाहरण

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

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

#Doping EMPLOYEE table if already exists.
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")

#Creating a table
sql = '''CREATE TABLE EMPLOYEE(
   FIRST_NAME CHAR(20) NOT NULL,
   LAST_NAME CHAR(20),
   AGE INT, SEX CHAR(1),
   INCOME INT,
   CONTACT INT)'''
cursor.execute(sql)

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

data = [('Krishna', 'Sharma', 26, 'M', 2000, 101), 
   ('Raj', 'Kandukuri', 20, 'M', 7000, 102),
   ('Ramya', 'Ramapriya', 29, 'F', 5000, 103),
   ('Mac', 'Mohan', 26, 'M', 2000, 104)]
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())

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

#Closing the connection
conn.close()

उत्पादन

[('Sharukh', 'Sheik', 25, 'M', 8300.0), ('Sarmista', 'Sharma', 26, 'F', 10000.0)]

आप UPDATE कथन का उपयोग करके PostgreSQL में एक तालिका के मौजूदा रिकॉर्ड की सामग्री को संशोधित कर सकते हैं। विशिष्ट पंक्तियों को अपडेट करने के लिए, आपको इसके साथ WHERE क्लॉज़ का उपयोग करना होगा।

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

PostgreSQL में UPDATE स्टेटमेंट का सिंटैक्स निम्नलिखित है -

UPDATE table_name
SET column1 = value1, column2 = value2...., columnN = valueN
WHERE [condition];

उदाहरण

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

postgres=# CREATE TABLE CRICKETERS ( 
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#

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

postgres=# insert into CRICKETERS values('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1

निम्नलिखित कथन क्रिकेटर की आयु को संशोधित करता है, जिसका पहला नाम है Shikhar -

postgres=# UPDATE CRICKETERS SET AGE = 45 WHERE FIRST_NAME = 'Shikhar' ;
UPDATE 1
postgres=#

यदि आप उस रिकॉर्ड को पुनः प्राप्त करते हैं जिसका FIRST_NAME शिखर है, तो आप देखते हैं कि आयु मान 45 में बदल दिया गया है -

postgres=# SELECT * FROM CRICKETERS WHERE FIRST_NAME = 'Shikhar';
 first_name | last_name | age | place_of_birth | country
------------+-----------+-----+----------------+---------
Shikhar     | Dhawan    | 45  | Delhi          | India
(1 row)

postgres=#

यदि आपने WHERE क्लॉज का उपयोग नहीं किया है, तो सभी रिकॉर्ड के मान अपडेट किए जाएंगे। UPDATE के बयान के बाद CRICKETERS तालिका में सभी रिकॉर्डों की आयु 1 से बढ़ जाती है -

postgres=# UPDATE CRICKETERS SET AGE = AGE+1;
UPDATE 5

यदि आप SELECT कमांड का उपयोग करके तालिका की सामग्री को पुनः प्राप्त करते हैं, तो आप अद्यतन मानों को देख सकते हैं -

postgres=# SELECT * FROM CRICKETERS;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
Jonathan    | Trott      | 39  | CapeTown       | SouthAfrica
Kumara      | Sangakkara | 42  | Matale         | Srilanka
Virat       | Kohli      | 31  | Delhi          | India
Rohit       | Sharma     | 33  | Nagpur         | India
Shikhar     | Dhawan     | 46  | Delhi          | India
(5 rows)

पायथन का उपयोग करके रिकॉर्ड अपडेट करना

Psycopg2 का कर्सर वर्ग नाम निष्पादित () विधि के साथ एक विधि प्रदान करता है। यह विधि क्वेरी को एक पैरामीटर के रूप में स्वीकार करती है और इसे निष्पादित करती है।

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

  • आयात psycopg2 पैकेज।

  • का उपयोग कर एक कनेक्शन ऑब्जेक्ट बनाएँ connect() विधि, उपयोगकर्ता नाम, पासवर्ड, होस्ट (वैकल्पिक डिफ़ॉल्ट: लोकलहोस्ट) और, डेटाबेस (वैकल्पिक) को मापदंडों के रूप में पारित करके।

  • विशेषता के मान के रूप में गलत सेट करके ऑटो-कम मोड को बंद करें autocommit

  • cursor() की विधि Connectionpsycopg2 लाइब्रेरी का क्लास एक कर्सर ऑब्जेक्ट देता है। इस पद्धति का उपयोग करके एक कर्सर ऑब्जेक्ट बनाएं।

  • फिर, निष्पादित () विधि के लिए एक पैरामीटर के रूप में पास करके अद्यतन विवरण को निष्पादित करें।

उदाहरण

पायथन कोड के बाद कर्मचारी तालिका की सामग्री को अद्यतन करता है और परिणाम प्राप्त करता है -

import psycopg2
#establishing the connection
conn = psycopg2.connect (
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

#Fetching all the rows before the update
print("Contents of the Employee table: ")
sql = '''SELECT * from EMPLOYEE'''
cursor.execute(sql)
print(cursor.fetchall())

#Updating the records
sql = "UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE SEX = 'M'"
cursor.execute(sql)
print("Table updated...... ")

#Fetching all the rows after the update
print("Contents of the Employee table after the update operation: ")
sql = '''SELECT * from EMPLOYEE'''
cursor.execute(sql)
print(cursor.fetchall())

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

#Closing the connection
conn.close()

उत्पादन

Contents of the Employee table:
[
   ('Ramya', 'Rama priya', 27, 'F', 9000.0), 
   ('Vinay', 'Battacharya', 20, 'M', 6000.0), 
   ('Sharukh', 'Sheik', 25, 'M', 8300.0), 
   ('Sarmista', 'Sharma', 26, 'F', 10000.0), 
   ('Tripthi', 'Mishra', 24, 'F', 6000.0)
]
Table updated......
Contents of the Employee table after the update operation:
[
   ('Ramya', 'Rama priya', 27, 'F', 9000.0), 
   ('Sarmista', 'Sharma', 26, 'F', 10000.0), 
   ('Tripthi', 'Mishra', 24, 'F', 6000.0), 
   ('Vinay', 'Battacharya', 21, 'M', 6000.0), 
   ('Sharukh', 'Sheik', 26, 'M', 8300.0)
]

आप किसी मौजूदा तालिका में रिकॉर्ड का उपयोग करके हटा सकते हैं DELETE FROMPostgreSQL डेटाबेस का विवरण। विशिष्ट रिकॉर्ड को निकालने के लिए, आपको इसके साथ WHERE क्लॉज़ का उपयोग करना होगा।

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

PostgreSQL में DELETE क्वेरी का सिंटैक्स निम्नलिखित है -

DELETE FROM table_name [WHERE Clause]

उदाहरण

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

postgres=# CREATE TABLE CRICKETERS ( 
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#

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

postgres=# insert into CRICKETERS values ('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1

निम्नलिखित कथन से उस क्रिकेटर का रिकॉर्ड हटा दिया जाता है जिसका अंतिम नाम 'संगकारा' है।

postgres=# DELETE FROM CRICKETERS WHERE LAST_NAME = 'Sangakkara';
DELETE 1

यदि आप SELECT स्टेटमेंट का उपयोग करके तालिका की सामग्री को पुनः प्राप्त करते हैं, तो आप केवल 4 रिकॉर्ड देख सकते हैं क्योंकि हमने एक को हटा दिया है।

postgres=# SELECT * FROM CRICKETERS;
 first_name | last_name | age | place_of_birth | country
------------+-----------+-----+----------------+-------------
Jonathan    |     Trott |  39 | CapeTown       | SouthAfrica
Virat       |     Kohli |  31 | Delhi          | India
Rohit       |    Sharma |  33 | Nagpur         | India
Shikhar     |    Dhawan |  46 | Delhi          | India

(4 rows)

यदि आप DELETE FROM स्टेटमेंट को निष्पादित करते हैं तो WHERE क्लॉज के बिना निर्दिष्ट तालिका से सभी रिकॉर्ड हटा दिए जाएंगे।

postgres=# DELETE FROM CRICKETERS;
DELETE 4

चूंकि आपने सभी रिकॉर्ड हटा दिए हैं, अगर आप CRICKETERS तालिका की सामग्री को पुनः प्राप्त करने का प्रयास करते हैं, तो SELECT स्टेटमेंट का उपयोग करके आपको नीचे दिखाए गए अनुसार एक खाली परिणाम सेट मिलेगा -

postgres=# SELECT * FROM CRICKETERS;
 first_name | last_name | age | place_of_birth | country
------------+-----------+-----+----------------+---------
(0 rows)

पायथन का उपयोग करके डेटा हटाना

Psycopg2 का कर्सर वर्ग नाम निष्पादित () विधि के साथ एक विधि प्रदान करता है। यह विधि क्वेरी को एक पैरामीटर के रूप में स्वीकार करती है और इसे निष्पादित करती है।

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

  • आयात psycopg2 पैकेज।

  • का उपयोग कर एक कनेक्शन ऑब्जेक्ट बनाएँ connect() विधि, उपयोगकर्ता नाम, पासवर्ड, होस्ट (वैकल्पिक डिफ़ॉल्ट: लोकलहोस्ट) और, डेटाबेस (वैकल्पिक) को मापदंडों के रूप में पारित करके।

  • विशेषता के मान के रूप में गलत सेट करके ऑटो-कम मोड को बंद करें autocommit

  • cursor() की विधि Connectionpsycopg2 लाइब्रेरी का क्लास एक कर्सर ऑब्जेक्ट देता है। इस पद्धति का उपयोग करके एक कर्सर ऑब्जेक्ट बनाएं।

  • फिर, निष्पादित () विधि के लिए एक पैरामीटर के रूप में पास करके DELETE विवरण निष्पादित करें।

उदाहरण

निम्नलिखित पायथन कोड 25 से अधिक उम्र के मूल्यों के साथ EMPLOYEE तालिका के रिकॉर्ड को हटाता है -

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

#Retrieving contents of the table
print("Contents of the table: ")
cursor.execute('''SELECT * from EMPLOYEE''')
print(cursor.fetchall())

#Deleting records
cursor.execute('''DELETE FROM EMPLOYEE WHERE AGE > 25''')

#Retrieving data after delete
print("Contents of the table after delete operation ")
cursor.execute("SELECT * from EMPLOYEE")
print(cursor.fetchall())

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

#Closing the connection
conn.close()

उत्पादन

Contents of the table:
[
   ('Ramya', 'Rama priya', 27, 'F', 9000.0), 
   ('Sarmista', 'Sharma', 26, 'F', 10000.0), 
   ('Tripthi', 'Mishra', 24, 'F', 6000.0), 
   ('Vinay', 'Battacharya', 21, 'M', 6000.0), 
   ('Sharukh', 'Sheik', 26, 'M', 8300.0)
]
Contents of the table after delete operation:
[  
   ('Tripthi', 'Mishra', 24, 'F', 6000.0), 
   ('Vinay', 'Battacharya', 21, 'M', 6000.0)
]

आप DROP टेबल स्टेटमेंट का उपयोग करके PostgreSQL डेटाबेस से एक टेबल ड्रॉप कर सकते हैं।

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

PostgreSQL में DROP टेबल स्टेटमेंट का सिंटैक्स निम्नलिखित है -

DROP TABLE table_name;

उदाहरण

मान लें कि हमने निम्नलिखित प्रश्नों का उपयोग करके CRICKETERS और EMPLOYEES नाम से दो तालिकाएँ बनाई हैं -

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#
postgres=# CREATE TABLE EMPLOYEE(
   FIRST_NAME CHAR(20) NOT NULL, LAST_NAME CHAR(20), 
   AGE INT, SEX CHAR(1), INCOME FLOAT
);
CREATE TABLE
postgres=#

अब यदि आप "\ dt" कमांड का उपयोग करते हुए तालिकाओं की सूची को सत्यापित करते हैं, तो आप ऊपर बनाई गई तालिकाओं को देख सकते हैं -

postgres=# \dt;
            List of relations
 Schema | Name       | Type  | Owner
--------+------------+-------+----------
 public | cricketers | table | postgres
 public | employee   | table | postgres
(2 rows)
postgres=#

निम्नलिखित कथन डेटाबेस से कर्मचारी नाम की तालिका को हटाता है -

postgres=# DROP table employee;
DROP TABLE

चूंकि आपने कर्मचारी तालिका को हटा दिया है, यदि आप फिर से तालिकाओं की सूची प्राप्त करते हैं, तो आप इसमें केवल एक तालिका का निरीक्षण कर सकते हैं।

postgres=# \dt;
            List of relations
Schema  | Name       | Type  | Owner
--------+------------+-------+----------
public  | cricketers | table | postgres
(1 row)


postgres=#

यदि आप कर्मचारी तालिका को फिर से हटाने की कोशिश करते हैं, क्योंकि आपने पहले ही इसे हटा दिया है, तो आपको एक त्रुटि मिलेगी जिसमें कहा गया है कि "तालिका मौजूद नहीं है" जैसा कि नीचे दिखाया गया है -

postgres=# DROP table employee;
ERROR: table "employee" does not exist
postgres=#

इसे हल करने के लिए, आप DELTE स्टेटमेंट के साथ IF EXISTS क्लॉज का उपयोग कर सकते हैं। यह तालिका को हटा देता है यदि यह मौजूद है तो DLETE ऑपरेशन को छोड़ देता है।

postgres=# DROP table IF EXISTS employee;
NOTICE: table "employee" does not exist, skipping
DROP TABLE
postgres=#

पायथन का उपयोग करके एक संपूर्ण तालिका निकालना

DROP स्टेटमेंट का उपयोग करके आपको जब भी जरूरत हो, एक टेबल ड्रॉप कर सकते हैं। लेकिन आपको किसी भी मौजूदा तालिका को हटाते समय बहुत सावधानी बरतने की आवश्यकता है क्योंकि किसी तालिका को हटाने के बाद खोए गए डेटा को पुनर्प्राप्त नहीं किया जाएगा।

import psycopg2
#establishing the connection
conn = psycopg2.connect(database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432')

#Setting auto commit false
conn.autocommit = True

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

#Doping EMPLOYEE table if already exists
cursor.execute("DROP TABLE emp")
print("Table dropped... ")

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

#Closing the connection
conn.close()

उत्पादन

#Table dropped...

PostgreSQL सेलेक्ट स्टेटमेंट को निष्पादित करते समय आप इसके परिणाम में रिकॉर्ड की संख्या को सीमित कर सकते हैं लिमाइट क्लॉज का उपयोग कर।

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

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

SELECT column1, column2, columnN
FROM table_name
LIMIT [no of rows]

उदाहरण

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

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255), Last_Name VARCHAR(255), 
   Age int, Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
CREATE TABLE
postgres=#

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

postgres=# insert into CRICKETERS values ('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Virat', 'Kohli', 30, 'Delhi', 'India');
INSERT 0 1
postgres=# insert into CRICKETERS values ('Rohit', 'Sharma', 32, 'Nagpur', 'India');
INSERT 0 1

निम्नलिखित कथन लिमिट क्लॉज का उपयोग करके क्रिकेटरों की तालिका के पहले 3 रिकॉर्ड्स को पुनः प्राप्त करता है -

postgres=# SELECT * FROM CRICKETERS LIMIT 3;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+-------------
 Shikhar    | Dhawan     | 33  | Delhi          | India
 Jonathan   | Trott      | 38  | CapeTown       | SouthAfrica
 Kumara     | Sangakkara | 41  | Matale         | Srilanka

   (3 rows)

यदि आप एक विशेष रिकॉर्ड (ऑफसेट) से रिकॉर्ड प्राप्त करना चाहते हैं, तो आप ऐसा कर सकते हैं, लिफ़िट के साथ OFFSET क्लॉज का उपयोग कर सकते हैं।

postgres=# SELECT * FROM CRICKETERS LIMIT 3 OFFSET 2;
 first_name | last_name  | age | place_of_birth | country
------------+------------+-----+----------------+----------
 Kumara     | Sangakkara | 41  | Matale         | Srilanka
 Virat      | Kohli      | 30  | Delhi          | India
 Rohit      | Sharma     | 32  | Nagpur         | India

   (3 rows)
postgres=#

पायथन का उपयोग करके क्लॉज को सीमित करें

पायथन उदाहरण के बाद EMPLOYEE नाम की एक तालिका की सामग्री प्राप्त होती है, जो 2 के परिणाम में रिकॉर्ड की संख्या को सीमित करती है -

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

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

#Closing the connection
conn.close()

उत्पादन

[('Sharukh', 'Sheik', 25, 'M', 8300.0), ('Sarmista', 'Sharma', 26, 'F', 10000.0)]

जब आपने डेटा को दो तालिकाओं में विभाजित किया है, तो आप इन दो तालिकाओं से जोड़ों का उपयोग करके संयुक्त रिकॉर्ड प्राप्त कर सकते हैं।

उदाहरण

मान लें कि हमने CRICKETERS नाम से एक तालिका बनाई है और उसमें 5 रिकॉर्ड डाले हैं, जैसा कि नीचे दिखाया गया है -

postgres=# CREATE TABLE CRICKETERS (
   First_Name VARCHAR(255), Last_Name VARCHAR(255), Age int, 
   Place_Of_Birth VARCHAR(255), Country VARCHAR(255)
);
postgres=# insert into CRICKETERS values ('Shikhar', 'Dhawan', 33, 'Delhi', 'India');
postgres=# insert into CRICKETERS values ('Jonathan', 'Trott', 38, 'CapeTown', 'SouthAfrica');
postgres=# insert into CRICKETERS values ('Kumara', 'Sangakkara', 41, 'Matale', 'Srilanka');
postgres=# insert into CRICKETERS values ('Virat', 'Kohli', 30, 'Delhi', 'India');
postgres=# insert into CRICKETERS values ('Rohit', 'Sharma', 32, 'Nagpur', 'India');

और, अगर हमने OdiStats नाम से एक और तालिका बनाई है और उसमें 5 रिकॉर्ड डाले हैं -

postgres=# CREATE TABLE ODIStats (
   First_Name VARCHAR(255), Matches INT, Runs INT, AVG FLOAT, 
   Centuries INT, HalfCenturies INT
);
postgres=# insert into OdiStats values ('Shikhar', 133, 5518, 44.5, 17, 27);
postgres=# insert into OdiStats values ('Jonathan', 68, 2819, 51.25, 4, 22);
postgres=# insert into OdiStats values ('Kumara', 404, 14234, 41.99, 25, 93);
postgres=# insert into OdiStats values ('Virat', 239, 11520, 60.31, 43, 54);
postgres=# insert into OdiStats values ('Rohit', 218, 8686, 48.53, 24, 42);

निम्नलिखित कथन इन दो तालिकाओं में मूल्यों के संयोजन डेटा को पुनः प्राप्त करता है -

postgres=# SELECT
   Cricketers.First_Name, Cricketers.Last_Name, Cricketers.Country,
   OdiStats.matches, OdiStats.runs, OdiStats.centuries, OdiStats.halfcenturies
   from Cricketers INNER JOIN OdiStats ON Cricketers.First_Name = OdiStats.First_Name;
 first_name | last_name  | country     | matches | runs  | centuries | halfcenturies
------------+------------+-------------+---------+-------+-----------+---------------
 Shikhar    | Dhawan     | India       | 133     | 5518  | 17        | 27
 Jonathan   | Trott      | SouthAfrica | 68      | 2819  | 4         | 22
 Kumara     | Sangakkara | Srilanka    | 404     | 14234 | 25        | 93
 Virat      | Kohli      | India       | 239     | 11520 | 43        | 54
 Rohit      | Sharma     | India       | 218     | 8686  | 24        | 42
(5 rows)
   
postgres=#

पायथन का उपयोग करके जुड़ता है

जब आपने डेटा को दो तालिकाओं में विभाजित किया है, तो आप इन दो तालिकाओं से जोड़ों का उपयोग करके संयुक्त रिकॉर्ड प्राप्त कर सकते हैं।

उदाहरण

अजगर कार्यक्रम के बाद जॉय खंड के उपयोग को दर्शाता है -

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

#Retrieving single row
sql = '''SELECT * from EMP INNER JOIN CONTACT ON EMP.CONTACT = CONTACT.ID'''

#Executing the query
cursor.execute(sql)

#Fetching 1st row from the table
result = cursor.fetchall();
print(result)

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

#Closing the connection
conn.close()

उत्पादन

[
   ('Ramya', 'Rama priya', 27, 'F', 9000.0, 101, 101, '[email protected]', 'Hyderabad'), 
   ('Vinay', 'Battacharya', 20, 'M', 6000.0, 102, 102, '[email protected]', 'Vishakhapatnam'), 
   ('Sharukh', 'Sheik', 25, 'M', 8300.0, 103, 103, '[email protected] ', 'Pune'), 
   ('Sarmista', 'Sharma', 26, 'F', 10000.0, 104, 104, '[email protected]', 'Mumbai')
]

Psycopg लाइब्रेरी के कर्सर वर्ग को अजगर कोड का उपयोग करके डेटाबेस में PostgreSQL कमांड को निष्पादित करने के तरीके प्रदान करते हैं।

इसके तरीकों का उपयोग करके आप SQL कथनों को निष्पादित कर सकते हैं, परिणाम सेट, कॉल प्रक्रियाओं से डेटा प्राप्त कर सकते हैं।

आप बना सकते हैं Cursor कनेक्शन ऑब्जेक्ट / कक्षा के कर्सर () पद्धति का उपयोग करके ऑब्जेक्ट।

उदाहरण

import psycopg2
#establishing the connection
conn = psycopg2.connect(
   database="mydb", user='postgres', password='password', host='127.0.0.1', port= '5432'
)

#Setting auto commit false
conn.autocommit = True

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

तरीकों

निम्नलिखित विभिन्न तरीके Cursor वर्ग / वस्तु द्वारा प्रदान किए गए हैं।

अनु क्रमांक। तरीके और विवरण
1

callproc()

इस विधि का उपयोग मौजूदा प्रक्रियाओं PostgreSQL डेटाबेस को कॉल करने के लिए किया जाता है।

2

close()

वर्तमान कर्सर ऑब्जेक्ट को बंद करने के लिए इस विधि का उपयोग किया जाता है।

3

executemany()

यह विधि पैरामीटर सूची की सूची श्रृंखला को स्वीकार करती है। एक MySQL क्वेरी तैयार करता है और इसे सभी मापदंडों के साथ निष्पादित करता है।

4

execute()

यह विधि एक पैरामीटर के रूप में MySQL क्वेरी को स्वीकार करती है और दिए गए क्वेरी को निष्पादित करती है।

5

fetchall()

यह विधि किसी क्वेरी के परिणाम सेट में सभी पंक्तियों को पुनर्प्राप्त करती है और उन्हें टुपल्स की सूची के रूप में वापस करती है। (यदि हम इसे कुछ पंक्तियों को प्राप्त करने के बाद निष्पादित करते हैं तो यह शेष लोगों को वापस कर देता है)

6

fetchone()

यह विधि क्वेरी के परिणाम में अगली पंक्ति लाती है और इसे टुप के रूप में लौटाती है।

7

fetchmany()

यह विधि भ्रूण के समान है (), लेकिन यह एक पंक्ति के बजाय, क्वेरी के परिणाम सेट में पंक्तियों के अगले सेट को पुनः प्राप्त करता है।

गुण

निम्नलिखित कर्सर श्रेणी के गुण हैं -

अनु क्रमांक। संपत्ति विवरण
1

description

यह एक रीड ओनली प्रॉपर्टी है, जो रिजल्ट-सेट में कॉलम के विवरण वाली सूची लौटाती है।

2

lastrowid

यह एक रीड ओनली प्रॉपर्टी है, यदि तालिका में कोई भी ऑटो-इन्क्रिमेटेड कॉलम हैं, तो यह उस कॉलम के लिए उत्पन्न मूल्य को पिछले INSERT या, UPDATE ऑपरेशन में लौटाता है।

3

rowcount

यह SELECT और UPDATE ऑपरेशन की स्थिति में लौटी / अपडेट की गई पंक्तियों की संख्या लौटाता है।

4

closed

यह गुण निर्दिष्ट करता है कि कोई कर्सर बंद है या नहीं, यदि ऐसा है तो यह सही है, अन्यथा गलत है।

5

connection

यह कनेक्शन ऑब्जेक्ट का संदर्भ देता है जिसके उपयोग से यह कर्सर बनाया गया था।

6

name

यह संपत्ति कर्सर का नाम लौटाती है।

7

scrollable

यह गुण निर्दिष्ट करता है कि क्या कोई विशेष कर्सर स्क्रॉल करने योग्य है।