PostgreSQL - पर्ल इंटरफ़ेस
इंस्टालेशन
PostgreSQL को पर्ल डीबीआई मॉड्यूल का उपयोग करके पर्ल के साथ एकीकृत किया जा सकता है, जो पर्ल प्रोग्रामिंग भाषा के लिए डेटाबेस एक्सेस मॉड्यूल है। यह कई तरीकों, चर और सम्मेलनों को परिभाषित करता है जो एक मानक डेटाबेस इंटरफ़ेस प्रदान करते हैं।
यहां आपके लिनक्स / यूनिक्स मशीन पर डीबीआई मॉड्यूल स्थापित करने के सरल उपाय दिए गए हैं -
$ wget http://search.cpan.org/CPAN/authors/id/T/TI/TIMB/DBI-1.625.tar.gz
$ tar xvfz DBI-1.625.tar.gz
$ cd DBI-1.625
$ perl Makefile.PL
$ make
$ make install
यदि आपको DBI के लिए SQLite ड्राइवर स्थापित करने की आवश्यकता है, तो इसे निम्नानुसार स्थापित किया जा सकता है -
$ wget http://search.cpan.org/CPAN/authors/id/T/TU/TURNSTEP/DBD-Pg-2.19.3.tar.gz
$ tar xvfz DBD-Pg-2.19.3.tar.gz
$ cd DBD-Pg-2.19.3
$ perl Makefile.PL
$ make
$ make install
इससे पहले कि आप पर्ल PostgreSQL इंटरफ़ेस का उपयोग शुरू करें, खोजें pg_hba.conf अपने PostgreSQL इंस्टॉलेशन डायरेक्टरी में फाइल करें और निम्न लाइन जोड़ें -
# IPv4 local connections:
host all all 127.0.0.1/32 md5
यदि आप निम्न आदेश का उपयोग कर नहीं चल रहे हैं, तो आप पोस्टग्रेज सर्वर को शुरू / पुनः आरंभ कर सकते हैं -
[root@host]# service postgresql restart
Stopping postgresql service: [ OK ]
Starting postgresql service: [ OK ]
DBI इंटरफ़ेस APIs
निम्नलिखित महत्वपूर्ण डीबीआई रूटीन हैं, जो आपके पर्ल प्रोग्राम से SQLite डेटाबेस के साथ काम करने की आवश्यकता को पूरा कर सकते हैं। यदि आप अधिक परिष्कृत आवेदन की तलाश में हैं, तो आप पर्ल डीबीआई के आधिकारिक दस्तावेज देख सकते हैं।
एस। | एपीआई और विवरण |
---|---|
1 | DBI→connect($data_source, "userid", "password", \%attr) अनुरोधित $ data_source पर एक डेटाबेस कनेक्शन या सत्र स्थापित करता है। यदि कनेक्शन सफल होता है तो डेटाबेस हैंडल ऑब्जेक्ट लौटाता है। डाटासोर्स का रूप है: DBI:Pg:dbname=$database;host=127.0.0.1;port=5432 Pg PostgreSQL ड्राइवर का नाम है और testdb डेटाबेस का नाम है। |
2 | $dbh→do($sql) यह रूटीन एक एकल एसक्यूएल स्टेटमेंट को तैयार और कार्यान्वित करता है। त्रुटि पर प्रभावित या अपरिभाषित पंक्तियों की संख्या लौटाता है। -1 के रिटर्न मान का मतलब है कि पंक्तियों की संख्या ज्ञात नहीं है, लागू नहीं है, या उपलब्ध नहीं है। यहाँ $ dbh DBI → Connect () कॉल द्वारा लौटाया गया एक हैंडल है। |
3 | $dbh→prepare($sql) यह रूटीन बाद में डेटाबेस इंजन द्वारा निष्पादन के लिए एक स्टेटमेंट तैयार करता है और एक स्टेटमेंट हैंडल ऑब्जेक्ट का संदर्भ देता है। |
4 | $sth→execute() यह दिनचर्या तैयार विवरण को निष्पादित करने के लिए जो भी प्रसंस्करण आवश्यक है, करती है। यदि कोई त्रुटि होती है तो एक अपरिभाषित लौटा दिया जाता है। एक सफल निष्पादन हमेशा प्रभावित पंक्तियों की संख्या की परवाह किए बिना सही रिटर्न देता है। यहाँ $ sth $ dbh → रेडी ($ sql) कॉल द्वारा दिया गया स्टेटमेंट हैंडल है। |
5 | $sth→fetchrow_array() यह दिनचर्या डेटा की अगली पंक्ति लाती है और इसे फ़ील्ड मानों की सूची के रूप में लौटाती है। सूची में अशक्त मानों के रूप में अशक्त फ़ील्ड वापस कर दिए जाते हैं। |
6 | $DBI::err यह $ h → इरेट के बराबर है, जहाँ $ h किसी भी प्रकार के हैंडल जैसे $ dbh, $ sth, या $ drh है। यह मूल ड्राइवर इंजन त्रुटि कोड को अंतिम ड्राइवर विधि से लौटाता है जिसे कहा जाता है। |
7 | $DBI::errstr यह $ h → इप्ट्रस्ट के बराबर है, जहां $ h किसी भी प्रकार के हैंडल जैसे $ dbh, $ sth, या अन्य drh है। यह मूल डेटाबेस इंजन त्रुटि संदेश को अंतिम DBI विधि से लौटाता है जिसे कहा जाता है। |
8 | $dbh->disconnect() यह दिनचर्या डीबीआई → कनेक्ट () से कॉल द्वारा खोले गए डेटाबेस कनेक्शन को बंद कर देती है। |
डेटाबेस से जुड़ना
निम्न पर्ल कोड दिखाता है कि मौजूदा डेटाबेस से कैसे जुड़ा जाए। यदि डेटाबेस मौजूद नहीं है, तो इसे बनाया जाएगा और अंत में एक डेटाबेस ऑब्जेक्ट वापस कर दिया जाएगा।
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "Pg";
my $database = "testdb";
my $dsn = "DBI:$driver:dbname = $database;host = 127.0.0.1;port = 5432";
my $userid = "postgres";
my $password = "pass123";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
अब, हम अपने डेटाबेस को खोलने के लिए ऊपर दिए गए प्रोग्राम को चलाते हैं testdb; यदि डेटाबेस सफलतापूर्वक खोला जाता है तो यह निम्नलिखित संदेश देगा -
Open database successfully
एक तालिका बनाएँ
पहले बनाए गए डेटाबेस में तालिका बनाने के लिए निम्नलिखित पर्ल प्रोग्राम का उपयोग किया जाएगा -
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "Pg";
my $database = "testdb";
my $dsn = "DBI:$driver:dbname=$database;host=127.0.0.1;port=5432";
my $userid = "postgres";
my $password = "pass123";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(CREATE TABLE COMPANY
(ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL););
my $rv = $dbh->do($stmt);
if($rv < 0) {
print $DBI::errstr;
} else {
print "Table created successfully\n";
}
$dbh->disconnect();
जब ऊपर दिए गए प्रोग्राम को निष्पादित किया जाता है, तो यह आपके में कंपनी तालिका बनाएगा testdb और यह निम्नलिखित संदेश प्रदर्शित करेगा -
Opened database successfully
Table created successfully
INSERT ऑपरेशन
निम्नलिखित पर्ल कार्यक्रम दिखाता है कि हम अपनी कंपनी तालिका में उपरोक्त उदाहरण में रिकॉर्ड कैसे बना सकते हैं -
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "Pg";
my $database = "testdb";
my $dsn = "DBI:$driver:dbname = $database;host = 127.0.0.1;port = 5432";
my $userid = "postgres";
my $password = "pass123";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 ));
my $rv = $dbh->do($stmt) or die $DBI::errstr;
$stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (2, 'Allen', 25, 'Texas', 15000.00 ));
$rv = $dbh->do($stmt) or die $DBI::errstr;
$stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (3, 'Teddy', 23, 'Norway', 20000.00 ));
$rv = $dbh->do($stmt) or die $DBI::errstr;
$stmt = qq(INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 ););
$rv = $dbh->do($stmt) or die $DBI::errstr;
print "Records created successfully\n";
$dbh->disconnect();
जब ऊपर दिए गए प्रोग्राम को निष्पादित किया जाता है, तो यह कंपनी की तालिका में दिए गए रिकॉर्ड बनाएगा और निम्नलिखित दो लाइनें प्रदर्शित करेगा -
Opened database successfully
Records created successfully
ऑपरेशन का चयन करें
निम्नलिखित पर्ल कार्यक्रम दिखाता है कि हम उपरोक्त उदाहरण में बनाई गई हमारी कंपनी तालिका से रिकॉर्ड कैसे प्राप्त कर सकते हैं और प्रदर्शित कर सकते हैं -
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "Pg";
my $database = "testdb";
my $dsn = "DBI:$driver:dbname = $database;host = 127.0.0.1;port = 5432";
my $userid = "postgres";
my $password = "pass123";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(SELECT id, name, address, salary from COMPANY;);
my $sth = $dbh->prepare( $stmt );
my $rv = $sth->execute() or die $DBI::errstr;
if($rv < 0) {
print $DBI::errstr;
}
while(my @row = $sth->fetchrow_array()) {
print "ID = ". $row[0] . "\n";
print "NAME = ". $row[1] ."\n";
print "ADDRESS = ". $row[2] ."\n";
print "SALARY = ". $row[3] ."\n\n";
}
print "Operation done successfully\n";
$dbh->disconnect();
जब ऊपर दिए गए कार्यक्रम को निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -
Opened database successfully
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 20000
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000
Operation done successfully
अद्यतन ऑपरेशन
निम्नलिखित पर्ल कोड दिखाता है कि हम किसी भी रिकॉर्ड को अपडेट करने के लिए UPDATE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर कंपनी के नंबर 1 से अपडेट किए गए रिकॉर्ड को ला सकते हैं और प्रदर्शित कर सकते हैं।
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "Pg";
my $database = "testdb";
my $dsn = "DBI:$driver:dbname = $database;host = 127.0.0.1;port = 5432";
my $userid = "postgres";
my $password = "pass123";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(UPDATE COMPANY set SALARY = 25000.00 where ID=1;);
my $rv = $dbh->do($stmt) or die $DBI::errstr;
if( $rv < 0 ) {
print $DBI::errstr;
}else{
print "Total number of rows updated : $rv\n";
}
$stmt = qq(SELECT id, name, address, salary from COMPANY;);
my $sth = $dbh->prepare( $stmt );
$rv = $sth->execute() or die $DBI::errstr;
if($rv < 0) {
print $DBI::errstr;
}
while(my @row = $sth->fetchrow_array()) {
print "ID = ". $row[0] . "\n";
print "NAME = ". $row[1] ."\n";
print "ADDRESS = ". $row[2] ."\n";
print "SALARY = ". $row[3] ."\n\n";
}
print "Operation done successfully\n";
$dbh->disconnect();
जब ऊपर दिए गए कार्यक्रम को निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -
Opened database successfully
Total number of rows updated : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 25000
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000
Operation done successfully
DELETE ऑपरेशन
निम्न पर्ल कोड दिखाता है कि हम किसी भी रिकॉर्ड को हटाने के लिए DELETE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर किसी कंपनी कंपनी से शेष रिकॉर्ड प्राप्त और प्रदर्शित कर सकते हैं -
#!/usr/bin/perl
use DBI;
use strict;
my $driver = "Pg";
my $database = "testdb";
my $dsn = "DBI:$driver:dbname = $database;host = 127.0.0.1;port = 5432";
my $userid = "postgres";
my $password = "pass123";
my $dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
or die $DBI::errstr;
print "Opened database successfully\n";
my $stmt = qq(DELETE from COMPANY where ID=2;);
my $rv = $dbh->do($stmt) or die $DBI::errstr;
if( $rv < 0 ) {
print $DBI::errstr;
} else{
print "Total number of rows deleted : $rv\n";
}
$stmt = qq(SELECT id, name, address, salary from COMPANY;);
my $sth = $dbh->prepare( $stmt );
$rv = $sth->execute() or die $DBI::errstr;
if($rv < 0) {
print $DBI::errstr;
}
while(my @row = $sth->fetchrow_array()) {
print "ID = ". $row[0] . "\n";
print "NAME = ". $row[1] ."\n";
print "ADDRESS = ". $row[2] ."\n";
print "SALARY = ". $row[3] ."\n\n";
}
print "Operation done successfully\n";
$dbh->disconnect();
जब ऊपर दिए गए कार्यक्रम को निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -
Opened database successfully
Total number of rows deleted : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 25000
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000
Operation done successfully