java 連接Oracle數據庫

用java連接Oracle數據庫進行簡單的查詢

用sys登錄進sql plus
創建用戶
create user 用戶 identified by 密碼;
授權
grant connect,resource to 用戶;
grant selet any dictionary to 用戶;
grant OEM_MONITOR to 用戶;
grant create any view to grant create any view to jk028;;

以jk...登錄到sql plus上
conn jk...;
create table jk028.Student
(
Sno nvarchar2(16) not null,
Name nvarchar2(6),
Sex nchar(1),
Age smallint,
IdCard nvarchar2(20),
PoliticalStatus nvarchar2(6),
constraint pk_Sno primary key(Sno)
);

create table jk028.Course
(
Cno nvarchar2(16) not null,
CourseName nvarchar2(18),
Credit smallint,
constraint pk_Cno primary key(Cno)
);

create table jk028.SelectCourse
(
Sno nvarchar2(16) not null,
Cno nvarchar2(16) not null,
Score int,
constraint fk_Sno foreign key(Sno) references jk028.Student(Sno),
constraint fk_Cno foreign key(Cno) references jk028.Course(Cno)
);

create view jk028.V_學生成績
as
select s.Sno,s.Name,s.Sex,s.IdCard,c.CourseName,c.Credit,sc.Score
from jk028.SelectCourse sc join jk028.Student s on sc.Sno=s.Sno join jk028.Course c on sc.Cno=c.Cno;

添加數據:
Student

insert into jk028.Student values('1060315014001','王1','男',20,'610203199701192911','共青團員');
insert into jk028.Student values('1060315014002','王2','女',20,'610203199701192912','共青團員');
insert into jk028.Student values('1060315014003','王3','男',20,'610203199701192913','共青團員');
insert into jk028.Student values('1060315014004','王4','女',20,'610203199701192914','共青團員');
insert into jk028.Student values('1060315014005','王5','男',20,'610203199701192915','共青團員');

Course

insert into jk028.Course values('0001','數據庫',11);
insert into jk028.Course values('0002','馬克思原理',12);
insert into jk028.Course values('0003','數據挖掘',13);
insert into jk028.Course values('0004','軟件工程',14);
insert into jk028.Course values('0005','操作系統',15);

SelectCourse

insert into jk028.SelectCourse values('1060315014001','0001',91);
insert into jk028.SelectCourse values('1060315014002','0001',91);
insert into jk028.SelectCourse values('1060315014003','0001',91);
insert into jk028.SelectCourse values('1060315014004','0001',91);
insert into jk028.SelectCourse values('1060315014005','0001',91);

先將外部jar引入到項目文件中 將Oracle/product/11.2.0//db_home/jdbc/lib中的ojdbc6文件引入

package oraclework;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class ConnOracle {

private static Connection con ;
private static String user = "jk028" ; //數據庫賬號
private static String password = "123456" ;// 數據庫密碼
private static String className = "oracle.jdbc.driver.OracleDriver" ;
private static String url = "jdbc:oracle:thin:@127.0.0.1:1521:Oraclewk" ; br/>//"jdbc:oracle:thin:@127.0.0.1:1521:Oraclewk"
//參照數據庫文件 Oracle/product/11.2.0//db_home/NETWORK/ADMIN/tnsnames文件中的參數
//hostname: XL2LY877TNOBUUF
public static void main(String[] args) {
// TODO Auto-generated method stub
ConnOracle c = new ConnOracle();
c.ConnectOracle();
c.getCon();
c.closed();
}
public static ResultSet select(String sql){

ConnectOracle();
Connection conn=getCon();
ResultSet rs=null;
PreparedStatement pre=null;
try {
    pre=conn.prepareStatement(sql);;
    rs=pre.executeQuery(sql);
} catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}     
return rs;
}
public static void ConnectOracle() {  
       try {  
             Class. forName(className);  
             System. out.println("加載數據庫驅動成功!" );  
      } catch (ClassNotFoundException e ) {  
             System. out.println("加載數據庫驅動失敗!" );  
              e.printStackTrace();  
      }  

}

/** 創建數據庫連接 */  
public static Connection getCon() {  
       try {  
              con = DriverManager. getConnection(url, user, password);  
             System. out.println("創建數據庫連接成功!" );  
      } catch (SQLException e ) {  
             System. out.print(con );  
             System. out.println("創建數據庫連接失敗!" );  
              con = null;  
              e.printStackTrace();  
      }  
       return con ;  

}

public static void closed() {  
       try {  
              if (con != null) {  
                    con.close(); 
                    System.out.println("關閉數據庫連接成功!");
             }  
      } catch (SQLException e ) {  
             System. out.println("關閉con對象失敗!" );  
              e.printStackTrace();  
      }  

}
}

package oraclework;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Iterator;

public class StudentSelectCourse {
public static void main(String[] args) throws SQLException {
StudentSelectCourse ssc=new StudentSelectCourse();
String sql1="select from jk028.Student";
String sql2="select
from jk028.Course";
String sql3="select * from jk028.V_學生成績";
ssc.sqlselect(sql1);
ssc.sqlselect(sql2);
ssc.sqlselect(sql3);
}
public void sqlselect(String sql) throws SQLException{

  ResultSet rs=ConnOracle.select(sql);//學生表      
  try {
    while(rs.next()){
        int i=1;
         while(rs.getMetaData().getColumnCount()>=i){//列數
             System.out.print(rs.getNString(i++)+"\t");
         }
         System.out.println();
    }

} catch (SQLException e) {
    e.printStackTrace();
}
 rs.close();
 ConnOracle.closed();
}

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章