PostgreSQL - जावा इंटरफ़ेस

इंस्टालेशन

इससे पहले कि हम अपने जावा प्रोग्राम में PostgreSQL का उपयोग करना शुरू करें, हमें यह सुनिश्चित करने की आवश्यकता है कि हमारे पास PostgreSQL JDBC और जावा मशीन पर सेट है। आप अपने मशीन पर जावा इंस्टॉलेशन के लिए जावा ट्यूटोरियल की जांच कर सकते हैं। अब हम जाँचते हैं कि PostgreSQL JDBC ड्राइवर कैसे सेट करें।

  • का नवीनतम संस्करण डाउनलोड postgresql- (संस्करण) .jdbc.jar से PostgreSQL-JDBC भंडार।

  • अपने वर्ग पथ में डाउनलोड की गई जार फ़ाइल पोस्टग्रैसेक्- (VERSION) .jdbc.jar जोड़ें या आप उदाहरणों में नीचे बताए अनुसार -क्लासपैथ विकल्प के साथ इसका उपयोग कर सकते हैं।

निम्न अनुभाग मानता है कि आपको जावा JDBC अवधारणाओं के बारे में कम जानकारी है। यदि आपके पास नहीं है, तो नीचे दिए गए अवधारणाओं के साथ सहज होने के लिए JDBC ट्यूटोरियल के साथ आधे घंटे और घंटे बिताने का सुझाव दिया गया है ।

डेटाबेस से जुड़ना

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

import java.sql.Connection;
import java.sql.DriverManager;

public class PostgreSQLJDBC {
   public static void main(String args[]) {
      Connection c = null;
      try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager
            .getConnection("jdbc:postgresql://localhost:5432/testdb",
            "postgres", "123");
      } catch (Exception e) {
         e.printStackTrace();
         System.err.println(e.getClass().getName()+": "+e.getMessage());
         System.exit(0);
      }
      System.out.println("Opened database successfully");
   }
}

इससे पहले कि आप प्रोग्राम को संकलित करें और चलाएं, ढूंढें 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  ]

अब, हम testdb से जुड़ने के लिए उपरोक्त प्रोग्राम को संकलित करें और चलाएं। यहां, हम उपयोग कर रहे हैंpostgres उपयोगकर्ता आईडी के रूप में और 123डेटाबेस तक पहुँचने के लिए पासवर्ड के रूप में। आप इसे अपने डेटाबेस कॉन्फ़िगरेशन और सेटअप के अनुसार बदल सकते हैं। हम JDBC ड्राइवर के वर्तमान संस्करण को भी मान रहे हैंpostgresql-9.2-1002.jdbc3.jar वर्तमान पथ में उपलब्ध है।

C:\JavaPostgresIntegration>javac PostgreSQLJDBC.java
C:\JavaPostgresIntegration>java -cp c:\tools\postgresql-9.2-1002.jdbc3.jar;C:\JavaPostgresIntegration PostgreSQLJDBC
Open database successfully

एक तालिका बनाएँ

पूर्व में खोले गए डेटाबेस में तालिका बनाने के लिए निम्न जावा प्रोग्राम का उपयोग किया जाएगा। सुनिश्चित करें कि आपके लक्ष्य डेटाबेस में यह तालिका पहले से ही नहीं है।

import java.sql.*;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;


public class PostgreSQLJDBC {
   public static void main( String args[] ) {
      Connection c = null;
      Statement stmt = null;
      try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager
            .getConnection("jdbc:postgresql://localhost:5432/testdb",
            "manisha", "123");
         System.out.println("Opened database successfully");

         stmt = c.createStatement();
         String sql = "CREATE TABLE COMPANY " +
            "(ID INT PRIMARY KEY     NOT NULL," +
            " NAME           TEXT    NOT NULL, " +
            " AGE            INT     NOT NULL, " +
            " ADDRESS        CHAR(50), " +
            " SALARY         REAL)";
         stmt.executeUpdate(sql);
         stmt.close();
         c.close();
      } catch ( Exception e ) {
         System.err.println( e.getClass().getName()+": "+ e.getMessage() );
         System.exit(0);
      }
      System.out.println("Table created successfully");
   }
}

जब किसी प्रोग्राम को संकलित और निष्पादित किया जाता है, तो वह कंपनी तालिका बनाएगा testdb डेटाबेस और निम्नलिखित दो लाइनें प्रदर्शित करेगा -

Opened database successfully
Table created successfully

INSERT ऑपरेशन

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

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;

public class PostgreSQLJDBC {
   public static void main(String args[]) {
      Connection c = null;
      Statement stmt = null;
      try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager
            .getConnection("jdbc:postgresql://localhost:5432/testdb",
            "manisha", "123");
         c.setAutoCommit(false);
         System.out.println("Opened database successfully");

         stmt = c.createStatement();
         String sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
            + "VALUES (1, 'Paul', 32, 'California', 20000.00 );";
         stmt.executeUpdate(sql);

         sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
            + "VALUES (2, 'Allen', 25, 'Texas', 15000.00 );";
         stmt.executeUpdate(sql);

         sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
            + "VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );";
         stmt.executeUpdate(sql);

         sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "
            + "VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );";
         stmt.executeUpdate(sql);

         stmt.close();
         c.commit();
         c.close();
      } catch (Exception e) {
         System.err.println( e.getClass().getName()+": "+ e.getMessage() );
         System.exit(0);
      }
      System.out.println("Records created successfully");
   }
}

जब उपरोक्त कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह कंपनी तालिका में दिए गए रिकॉर्ड बनाएगा और निम्नलिखित दो लाइनें प्रदर्शित करेगा -

Opened database successfully
Records created successfully

ऑपरेशन का चयन करें

निम्नलिखित जावा कार्यक्रम दिखाता है कि हम उपरोक्त उदाहरण में बनाई गई हमारी कंपनी तालिका से रिकॉर्ड कैसे प्राप्त कर सकते हैं और प्रदर्शित कर सकते हैं -

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;


public class PostgreSQLJDBC {
   public static void main( String args[] ) {
      Connection c = null;
      Statement stmt = null;
      try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager
            .getConnection("jdbc:postgresql://localhost:5432/testdb",
            "manisha", "123");
         c.setAutoCommit(false);
         System.out.println("Opened database successfully");

         stmt = c.createStatement();
         ResultSet rs = stmt.executeQuery( "SELECT * FROM COMPANY;" );
         while ( rs.next() ) {
            int id = rs.getInt("id");
            String  name = rs.getString("name");
            int age  = rs.getInt("age");
            String  address = rs.getString("address");
            float salary = rs.getFloat("salary");
            System.out.println( "ID = " + id );
            System.out.println( "NAME = " + name );
            System.out.println( "AGE = " + age );
            System.out.println( "ADDRESS = " + address );
            System.out.println( "SALARY = " + salary );
            System.out.println();
         }
         rs.close();
         stmt.close();
         c.close();
      } catch ( Exception e ) {
         System.err.println( e.getClass().getName()+": "+ e.getMessage() );
         System.exit(0);
      }
      System.out.println("Operation done successfully");
   }
}

जब कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -

Opened database successfully
ID = 1
NAME = Paul
AGE = 32
ADDRESS = California
SALARY = 20000.0

ID = 2
NAME = Allen
AGE = 25
ADDRESS = Texas
SALARY = 15000.0

ID = 3
NAME = Teddy
AGE = 23
ADDRESS = Norway
SALARY = 20000.0

ID = 4
NAME = Mark
AGE = 25
ADDRESS = Rich-Mond
SALARY = 65000.0

Operation done successfully

अद्यतन ऑपरेशन

निम्न जावा कोड दिखाता है कि हम किसी भी रिकॉर्ड को अपडेट करने के लिए UPDATE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर अपनी कंपनी की टेबल से अपडेट किए गए रिकॉर्ड को ला सकते हैं और प्रदर्शित कर सकते हैं -

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;


public class PostgreSQLJDBC {
   public static void main( String args[] ) {
      Connection c = null;
      Statement stmt = null;
      try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager
            .getConnection("jdbc:postgresql://localhost:5432/testdb",
            "manisha", "123");
         c.setAutoCommit(false);
         System.out.println("Opened database successfully");

         stmt = c.createStatement();
         String sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1;";
         stmt.executeUpdate(sql);
         c.commit();

         ResultSet rs = stmt.executeQuery( "SELECT * FROM COMPANY;" );
         while ( rs.next() ) {
            int id = rs.getInt("id");
            String  name = rs.getString("name");
            int age  = rs.getInt("age");
            String  address = rs.getString("address");
            float salary = rs.getFloat("salary");
            System.out.println( "ID = " + id );
            System.out.println( "NAME = " + name );
            System.out.println( "AGE = " + age );
            System.out.println( "ADDRESS = " + address );
            System.out.println( "SALARY = " + salary );
            System.out.println();
         }
         rs.close();
         stmt.close();
         c.close();
      } catch ( Exception e ) {
         System.err.println( e.getClass().getName()+": "+ e.getMessage() );
         System.exit(0);
      }
      System.out.println("Operation done successfully");
   }
}

जब कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -

Opened database successfully
ID = 2
NAME = Allen
AGE = 25
ADDRESS = Texas
SALARY = 15000.0

ID = 3
NAME = Teddy
AGE = 23
ADDRESS = Norway
SALARY = 20000.0

ID = 4
NAME = Mark
AGE = 25
ADDRESS = Rich-Mond
SALARY = 65000.0

ID = 1
NAME = Paul
AGE = 32
ADDRESS = California
SALARY = 25000.0

Operation done successfully

DELETE ऑपरेशन

निम्नलिखित जावा कोड दिखाता है कि हम किसी भी रिकॉर्ड को हटाने के लिए DELETE स्टेटमेंट का उपयोग कैसे कर सकते हैं और फिर हमारी कंपनी की तालिका से शेष रिकॉर्ड प्राप्त कर सकते हैं और प्रदर्शित कर सकते हैं -

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;


public class PostgreSQLJDBC6 {
   public static void main( String args[] ) {
      Connection c = null;
      Statement stmt = null;
      try {
         Class.forName("org.postgresql.Driver");
         c = DriverManager
            .getConnection("jdbc:postgresql://localhost:5432/testdb",
            "manisha", "123");
         c.setAutoCommit(false);
         System.out.println("Opened database successfully");

         stmt = c.createStatement();
         String sql = "DELETE from COMPANY where ID = 2;";
         stmt.executeUpdate(sql);
         c.commit();

         ResultSet rs = stmt.executeQuery( "SELECT * FROM COMPANY;" );
         while ( rs.next() ) {
            int id = rs.getInt("id");
            String  name = rs.getString("name");
            int age  = rs.getInt("age");
            String  address = rs.getString("address");
            float salary = rs.getFloat("salary");
            System.out.println( "ID = " + id );
            System.out.println( "NAME = " + name );
            System.out.println( "AGE = " + age );
            System.out.println( "ADDRESS = " + address );
            System.out.println( "SALARY = " + salary );
            System.out.println();
         }
         rs.close();
         stmt.close();
         c.close();
      } catch ( Exception e ) {
         System.err.println( e.getClass().getName()+": "+ e.getMessage() );
         System.exit(0);
      }
      System.out.println("Operation done successfully");
   }
}

जब कार्यक्रम संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम देगा -

Opened database successfully
ID = 3
NAME = Teddy
AGE = 23
ADDRESS = Norway
SALARY = 20000.0

ID = 4
NAME = Mark
AGE = 25
ADDRESS = Rich-Mond
SALARY = 65000.0

ID = 1
NAME = Paul
AGE = 32
ADDRESS = California
SALARY = 25000.0
Operation done successfully