PostgreSQL - PHP इंटरफ़ेस
इंस्टालेशन
PostgreSQL एक्सटेंशन PHP 5.3.x के नवीनतम रिलीज़ में डिफ़ॉल्ट रूप से सक्षम है। इसका उपयोग करके इसे निष्क्रिय करना संभव है--without-pgsqlसंकलन के समय। फिर भी आप PHP -PostgreSQL इंटरफ़ेस स्थापित करने के लिए yum कमांड का उपयोग कर सकते हैं -
yum install php-pgsql
इससे पहले कि आप PHP 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 ]
Windows उपयोगकर्ताओं को इस एक्सटेंशन का उपयोग करने के लिए php_pgsql.dll सक्षम करना होगा। यह DLL PHP 5.3.x की नवीनतम रिलीज़ में विंडोज वितरण के साथ शामिल है
विस्तृत स्थापना निर्देशों के लिए, कृपया हमारे PHP ट्यूटोरियल और इसकी आधिकारिक वेबसाइट देखें।
PHP इंटरफ़ेस एपीआई
निम्नलिखित महत्वपूर्ण PHP रूटीन हैं, जो आपके PHP प्रोग्राम से PostgreSQL डेटाबेस के साथ काम करने की आपकी आवश्यकता को पूरा कर सकते हैं। यदि आप एक अधिक परिष्कृत अनुप्रयोग की तलाश कर रहे हैं, तो आप PHP आधिकारिक दस्तावेज में देख सकते हैं।
एस। | एपीआई और विवरण |
---|---|
1 | resource pg_connect ( string $connection_string [, int $connect_type ] ) यह कनेक्शन के द्वारा निर्दिष्ट PostgreSQL डेटाबेस के लिए एक कनेक्शन खोलता है। यदि PGSQL_CONNECT_FORCE_NEW को connect_type के रूप में पास किया जाता है, तो pg_connect () के लिए दूसरी कॉल के मामले में एक नया कनेक्शन बनाया जाता है, भले ही कनेक्शन_string किसी मौजूदा कनेक्शन के समान हो। |
2 | bool pg_connection_reset ( resource $connection ) यह दिनचर्या कनेक्शन को रीसेट करती है। यह त्रुटि सुधार के लिए उपयोगी है। सफलता पर सही या असफलता पर गलत रिटर्न करता है। |
3 | int pg_connection_status ( resource $connection ) यह दिनचर्या निर्दिष्ट कनेक्शन की स्थिति लौटाती है। PGSQL_CONNECTION_OK या PGSQL_CONNECTION_BAD देता है। |
4 | string pg_dbname ([ resource $connection ] ) यह रूटीन डेटाबेस का नाम देता है जो दिए गए PostgreSQL कनेक्शन संसाधन है। |
5 | resource pg_prepare ([ resource $connection ], string $stmtname, string $query ) यह दिए गए मापदंडों के साथ एक तैयार विवरण बनाने का अनुरोध करता है और पूरा होने का इंतजार करता है। |
6 | resource pg_execute ([ resource $connection ], string $stmtname, array $params ) यह दिनचर्या दिए गए मापदंडों के साथ तैयार विवरण को निष्पादित करने और परिणाम की प्रतीक्षा करने के लिए अनुरोध भेजती है। |
7 | resource pg_query ([ resource $connection ], string $query ) यह दिनचर्या निर्दिष्ट डेटाबेस कनेक्शन पर क्वेरी को निष्पादित करती है। |
8 | array pg_fetch_row ( resource $result [, int $row ] ) यह दिनचर्या निर्दिष्ट परिणाम संसाधन के साथ जुड़े परिणाम से डेटा की एक पंक्ति प्राप्त करती है। |
9 | array pg_fetch_all ( resource $result ) यह दिनचर्या एक सरणी देता है जिसमें परिणाम संसाधन में सभी पंक्तियाँ (रिकॉर्ड) होती हैं। |
10 | int pg_affected_rows ( resource $result ) यह रूटीन INSERT, UPDATE और DELETE क्वेरी से प्रभावित पंक्तियों की संख्या लौटाता है। |
1 1 | int pg_num_rows ( resource $result ) यह दिनचर्या पोस्टग्रेसीक्यूएल परिणाम संसाधन में पंक्तियों की संख्या का चयन करती है उदाहरण के लिए चयन कथन द्वारा दी गई पंक्तियों की संख्या। |
12 | bool pg_close ([ resource $connection ] ) यह रूटीन किसी दिए गए कनेक्शन संसाधन से जुड़े PostgreSQL डेटाबेस के लिए गैर-स्थाई कनेक्शन को बंद कर देता है। |
13 | string pg_last_error ([ resource $connection ] ) यह दिनचर्या किसी दिए गए कनेक्शन के लिए अंतिम त्रुटि संदेश देता है। |
14 | string pg_escape_literal ([ resource $connection ], string $data ) यह दिनचर्या पाठ क्षेत्र में प्रविष्टि के लिए एक शाब्दिक भाग है। |
15 | string pg_escape_string ([ resource $connection ], string $data ) यह रूटीन डेटाबेस को क्वेरी करने के लिए एक स्ट्रिंग से बच जाता है। |
डेटाबेस से जुड़ना
निम्न PHP कोड दिखाता है कि किसी स्थानीय मशीन पर मौजूदा डेटाबेस से कैसे कनेक्ट किया जाए और अंत में एक डेटाबेस कनेक्शन ऑब्जेक्ट वापस कर दिया जाएगा।
<?php
$host = "host = 127.0.0.1";
$port = "port = 5432";
$dbname = "dbname = testdb";
$credentials = "user = postgres password=pass123";
$db = pg_connect( "$host $port $dbname $credentials" );
if(!$db) {
echo "Error : Unable to open database\n";
} else {
echo "Opened database successfully\n";
}
?>
अब, हम अपने डेटाबेस को खोलने के लिए ऊपर दिए गए प्रोग्राम को चलाते हैं testdb: यदि डेटाबेस सफलतापूर्वक खोला जाता है, तो यह निम्नलिखित संदेश देगा -
Opened database successfully
एक तालिका बनाएँ
पहले से बनाए गए डेटाबेस में तालिका बनाने के लिए निम्नलिखित PHP प्रोग्राम का उपयोग किया जाएगा -
<?php
$host = "host = 127.0.0.1";
$port = "port = 5432";
$dbname = "dbname = testdb";
$credentials = "user = postgres password=pass123";
$db = pg_connect( "$host $port $dbname $credentials" );
if(!$db) {
echo "Error : Unable to open database\n";
} else {
echo "Opened database successfully\n";
}
$sql =<<<EOF
CREATE TABLE COMPANY
(ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL);
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
} else {
echo "Table created successfully\n";
}
pg_close($db);
?>
जब ऊपर दिए गए प्रोग्राम को निष्पादित किया जाता है, तो यह आपके में कंपनी तालिका बनाएगा testdb और यह निम्नलिखित संदेश प्रदर्शित करेगा -
Opened database successfully
Table created successfully
INSERT ऑपरेशन
निम्नलिखित PHP कार्यक्रम दिखाता है कि हम उपरोक्त उदाहरण में बनाई गई हमारी कंपनी तालिका में रिकॉर्ड कैसे बना सकते हैं -
<?php
$host = "host=127.0.0.1";
$port = "port=5432";
$dbname = "dbname = testdb";
$credentials = "user = postgres password=pass123";
$db = pg_connect( "$host $port $dbname $credentials" );
if(!$db) {
echo "Error : Unable to open database\n";
} else {
echo "Opened database successfully\n";
}
$sql =<<<EOF
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (2, 'Allen', 25, 'Texas', 15000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
} else {
echo "Records created successfully\n";
}
pg_close($db);
?>
जब ऊपर दिए गए प्रोग्राम को निष्पादित किया जाता है, तो यह कंपनी तालिका में दिए गए रिकॉर्ड बनाएगा और निम्नलिखित दो लाइनें प्रदर्शित करेगा -
Opened database successfully
Records created successfully
ऑपरेशन का चयन करें
निम्नलिखित PHP कार्यक्रम दिखाता है कि हम उपरोक्त उदाहरण में बनाई गई हमारी कंपनी तालिका से रिकॉर्ड कैसे प्राप्त कर सकते हैं और प्रदर्शित कर सकते हैं -
<?php
$host = "host = 127.0.0.1";
$port = "port = 5432";
$dbname = "dbname = testdb";
$credentials = "user = postgres password=pass123";
$db = pg_connect( "$host $port $dbname $credentials" );
if(!$db) {
echo "Error : Unable to open database\n";
} else {
echo "Opened database successfully\n";
}
$sql =<<<EOF
SELECT * from COMPANY;
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
exit;
}
while($row = pg_fetch_row($ret)) {
echo "ID = ". $row[0] . "\n";
echo "NAME = ". $row[1] ."\n";
echo "ADDRESS = ". $row[2] ."\n";
echo "SALARY = ".$row[4] ."\n\n";
}
echo "Operation done successfully\n";
pg_close($db);
?>
जब ऊपर दिए गए प्रोग्राम को निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा। ध्यान रखें कि फ़ील्ड को उस क्रम में लौटाया जाता है जिसका उपयोग तालिका बनाते समय किया गया था।
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
अद्यतन ऑपरेशन
निम्नलिखित PHP कोड दिखाता है कि हम किसी भी रिकॉर्ड को अपडेट करने के लिए UPDATE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर हमारी कंपनी की टेबल से अपडेट किए गए रिकॉर्ड प्राप्त और प्रदर्शित कर सकते हैं -
<?php
$host = "host=127.0.0.1";
$port = "port=5432";
$dbname = "dbname = testdb";
$credentials = "user = postgres password=pass123";
$db = pg_connect( "$host $port $dbname $credentials" );
if(!$db) {
echo "Error : Unable to open database\n";
} else {
echo "Opened database successfully\n";
}
$sql =<<<EOF
UPDATE COMPANY set SALARY = 25000.00 where ID=1;
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
exit;
} else {
echo "Record updated successfully\n";
}
$sql =<<<EOF
SELECT * from COMPANY;
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
exit;
}
while($row = pg_fetch_row($ret)) {
echo "ID = ". $row[0] . "\n";
echo "NAME = ". $row[1] ."\n";
echo "ADDRESS = ". $row[2] ."\n";
echo "SALARY = ".$row[4] ."\n\n";
}
echo "Operation done successfully\n";
pg_close($db);
?>
जब ऊपर दिए गए कार्यक्रम को निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -
Opened database successfully
Record updated successfully
ID = 2
NAME = Allen
ADDRESS = 25
SALARY = 15000
ID = 3
NAME = Teddy
ADDRESS = 23
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = 25
SALARY = 65000
ID = 1
NAME = Paul
ADDRESS = 32
SALARY = 25000
Operation done successfully
DELETE ऑपरेशन
निम्नलिखित PHP कोड दिखाता है कि हम किसी भी रिकॉर्ड को हटाने के लिए DELETE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर कंपनी के नंबर 1 से शेष रिकॉर्ड प्राप्त कर सकते हैं और प्रदर्शित कर सकते हैं
<?php
$host = "host = 127.0.0.1";
$port = "port = 5432";
$dbname = "dbname = testdb";
$credentials = "user = postgres password=pass123";
$db = pg_connect( "$host $port $dbname $credentials" );
if(!$db) {
echo "Error : Unable to open database\n";
} else {
echo "Opened database successfully\n";
}
$sql =<<<EOF
DELETE from COMPANY where ID=2;
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
exit;
} else {
echo "Record deleted successfully\n";
}
$sql =<<<EOF
SELECT * from COMPANY;
EOF;
$ret = pg_query($db, $sql);
if(!$ret) {
echo pg_last_error($db);
exit;
}
while($row = pg_fetch_row($ret)) {
echo "ID = ". $row[0] . "\n";
echo "NAME = ". $row[1] ."\n";
echo "ADDRESS = ". $row[2] ."\n";
echo "SALARY = ".$row[4] ."\n\n";
}
echo "Operation done successfully\n";
pg_close($db);
?>
जब ऊपर दिए गए कार्यक्रम को निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -
Opened database successfully
Record deleted successfully
ID = 3
NAME = Teddy
ADDRESS = 23
SALARY = 20000
ID = 4
NAME = Mark
ADDRESS = 25
SALARY = 65000
ID = 1
NAME = Paul
ADDRESS = 32
SALARY = 25000
Operation done successfully