Как показать Таблицы БД Oracle в моем фрейме проектов JDeveloper Swing? - PullRequest
0 голосов
/ 05 июля 2010

Я хочу показать свои таблицы БД Oracle в моем приложении.Я создаю новое соединение с базой данных DBConnection1.Но я не связываю DBConnection1 в моем классе.Как это сделать?

1 Ответ

0 голосов
/ 12 июля 2010

OK. Я решаю свой вопрос.

            DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
            Connection connection = DriverManager.getConnection(connStr,"scott","tiger"); 

            Connector conn = new Connector(connStr);
            Statement stmt = conn.getConnection().createStatement();                       

            ResultSet rset = stmt.executeQuery(sql); 
            ResultSetMetaData metaData = rset.getMetaData();

            int rowCount = metaData.getColumnCount();                 

            for(i=1;i<=rowCount;i++)
                headers.add(metaData.getColumnLabel(i).toString()); 


            while(rset.next()){          
                Vector tmp = new Vector();
                for(i=1;i<=rowCount;i++) {
                    tmp.add(rset.getString(i));              
                }
                lists.add(tmp);
                index++;                              

Вот мой класс соединителя.

package client;

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


public class Connector 
{
  private String connection_string;
  private Statement stmt;
  private Connection connection;

  public Connector(String conn)
  {
      //String connection_string = "jdbc:oracle:thin:@<host>:<port>:<db name>";
      try 
      {
        connection_string = conn;

        DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());  

        connection = DriverManager.getConnection(conn,"scott","tiger");                 

      } catch(Exception f) 
      {
        f.printStackTrace();
      }

  }

  public ResultSet execute(String sql) 
  {
     try 
     {
       stmt = connection.createStatement();
       return stmt.executeQuery(sql);
     } catch (Exception f) 
     {
       f.printStackTrace();
     }    
     return null;
  }


  public void setConnection_string(String connection_string)
  {
    this.connection_string = connection_string;
  }


  public String getConnection_string()
  {
    return connection_string;
  }


  public void setStmt(Statement stmt)
  {
    this.stmt = stmt;
  }


  public Statement getStmt()
  {
    return stmt;
  }


  public void setConnection(Connection connection)
  {
    this.connection = connection;
  }


  public Connection getConnection()
  {
    return connection;
  }
}
...