English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Tutorial básico PostgreSQL

Tutorial avançado PostgreSQL

Interface PostgreSQL

Interface PostgreSQL JAVA

instalação

Usando PostgreSQL em nosso programa Java Antes de começar a usar PostgreSQL em nosso programa Java, precisamos garantir que o PostgreSQL JDBC e o Java estejam configurados no computador. Você pode verificar Tutorial Java, para entender como instalar Java. Agora vamos verificar como configurar o driver postgresqljdbc.

  • Baixe a versão mais recente do postgresql a partir do endereço seguinte-(version).jdbc.jar postgresql-jdbc download.

  • adicionar o arquivo jar baixado postgresql-(VERSION).jar, ou você pode usá-lo com-A opção classpath pode ser usada junto com os exemplos a seguir.

A parte seguinte assume que você tem alguma compreensão do conceito javajdbc. Se não, é recomendável que você gaste meia hora estudando o tutorial JDBC para familiarizar-se com os conceitos explicados abaixo.

Conectar ao banco de dados

O seguinte código Java mostra como conectar a um banco de dados existente. Se o banco de dados não existir, ele será criado e, por fim, será retornado um objeto de banco de dados.

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");
   }
}

Antes de compilar e executar o programa acima, encontre o arquivo pg_hba.conf na pasta de instalação do PostgreSQL e crie um arquivo, adicionando as seguintes linhas:

# IPv4 conexões locais:
host	all	all         127.0.0.1/32          md5

Se o servidor postgres não estiver em execução, você pode usar o seguinte comando para iniciá-lo/Reinicie o servidor postgres

Agora, vamos compilar e executar o programa acima para conectar ao testdb. Aqui, usamos postgres como ID de usuário 123Como senha para acessar o banco de dados. Você pode alterá-la conforme a configuração e as configurações do banco de dados. Supomos ainda que a versão atual do driver JDBC postgresql-9.2-1002.jdbc3.jar está disponível no caminho atual.

C:\JavaPostgresIntegration>javac PostgreSQLJDBC.java
C:\JavaPostgresIntegration>java -cp c:\tools\postgresql-9.2-1002.jdbc3.jar;C:\JavaPostgresIntegration PostgresJDBC
Banco de dados aberto com sucesso

Criar tabela

O seguinte programa Java será usado para criar uma tabela no banco de dados aberto anteriormente. Certifique-se de que o banco de dados alvo não possui essa tabela.

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 = \ +
            "(ID INT PRIMÁRIA CHAVE  NOT NULL," +
            "NOME  TEXT  NOT NULL, \ +
            "IDADE  INT  NOT NULL, \ +
            "ENDEREÇO  CHAR(50), \ +
            "SALÁRIO  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("Tabela criada com sucesso");
   }
}

Ao compilar e executar o programa, ele criará a tabela COMPANY no banco de dados testdb e mostrará as seguintes duas linhas-

Banco de dados aberto com sucesso
Tabela criada com sucesso

Operação INSERT

O seguinte programa Java mostra como criar registros na tabela COMPANY criada no exemplo anterior-

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 = \
            + "VALORES ("1, \'Paul' 32, \'California' 20000,00 ");";
         stmt.executeUpdate(sql);
         sql = \
            + "VALORES ("2, \'Allen' 25, \'Texas' 15000,00 ");";
         stmt.executeUpdate(sql);
         sql = \
            + "VALORES ("3, \'Teddy' 23, \'Norway' 20000,00 ");";
         stmt.executeUpdate(sql);
         sql = \
            + "VALORES ("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("Registros criados com sucesso");
   }
}

在编译和执行上述程序时,它将在 COMPANY 表中创建给定的记录,并显示以下两行-

Banco de dados aberto com sucesso
Records created successfully

SELECT 操作

以下Java程序展示了我们如何从上面示例中创建的COMPANY表中获取和显示记录

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("Operação realizada com sucesso");
   }
}

Quando o programa é compilado e executado, os seguintes resultados são gerados

Banco de dados aberto com sucesso
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
Operação realizada com sucesso

UPDATE 操作

以下Java代码展示了如何使用UPDATE语句更新任何记录,然后从我们的COMPANY表中获取并显示更新后的记录

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("Operação realizada com sucesso");
   }
}

Quando o programa é compilado e executado, os seguintes resultados são gerados

Banco de dados aberto com sucesso
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
Operação realizada com sucesso

DELETE 操作

以下Java代码展示了如何使用DELETE语句删除任何记录,然后从我们的COMPANY表中获取并显示剩余的记录

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("Operação realizada com sucesso");
   }
}

Quando o programa é compilado e executado, os seguintes resultados são gerados

Banco de dados aberto com sucesso
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
Operação realizada com sucesso