Java連接Oracle數據庫的三種連接方式


背景:

這兩天在學習Oracle數據庫,這里就總結下自己上課所學的知識,同時記錄下來,方便整理當天所學下的知識,也同時方便日后自己查詢。

SQL語句的話,這里我就不多講了,感覺和其他的數據庫(MySQL、SQL Server)都是類似,區別不大。

今天在這里就寫下 Java 連接 Oracle 數據庫的三種連接方式。

工具:

  • Oracle Database 10g Express Edition
  • cmd命令窗口
  • IDEA 2016.1.3
  • ojdbc6_g.jar(數據庫驅動包)
  • jdk 1.8

創建數據庫表:

首先在本地寫好創建的數據庫表的創建代碼后,然后粘貼在cmd命令窗口下,即可創建成功。(前提是進入安裝好了oracle,進入了用戶,然后在當前用戶下創建這個表)

部門表:tb1_dept (含有id name city三個屬性)

1
2
3
4
5
create table tb1_dept(
id number(5) primary key,
name varchar2(10) not null,
city varchar2(10) not null
);

插入數據:

然后同樣寫好插入數據的sql語句,這里我就寫三條數據。

1
2
3
insert into tb1_dept(id, name, city) values(1,'java', '南昌');
insert into tb1_dept(id, name, city) values(2,'c', '上海');
insert into tb1_dept(id, name, city) values(3,'java', '南昌');

好,數據庫表已經創建好了,接下來我們需要准備的是數據庫驅動包。

這里我用的是 ojdbc6_g.jar 驅動包。

接下來先了解一些基礎知識:


JDBC的六大步驟:

這里我們就按照jdbc的這六大步驟執行下去:

  • 注冊驅動
  • 獲取連接
  • 獲取執行sql語句對象
  • 執行sql語句
  • 處理結果集
  • 關閉資源

URL:統一資源定位器

oracle URL: jdbc:oracle:thin:@localhost:1521:XE

jdbc:oracle:thin:@127.0.0.1:1521:XE

MySQL URL:jdbc:mysql://localhost:3306/數據庫名稱

thin:小型驅動,驅動方式

@localhost 本機ip地址 127.0.0.1

XE:數據庫的名字

ipconfig:ip地址查詢

URI:統一資源標識符

URN:用特定命名空間的名字標識資源

如果你不知道 URL、 URI、URN三者的區別的話,那么你可以參考下面我推薦的一篇文章。

你知道URL、URI和URN三者之間的區別嗎?


三種連接方式

代碼:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package cn.zhisheng.test.jdbc;

import oracle.jdbc.driver.OracleDriver;
import java.sql.*;
import java.util.Properties;
/**
* Created by 10412 on 2016/12/27.
* JDBC的六大步驟
* JAVA連接Oracle的三種方式
*/
public class JdbcTest
{
public static void main(String[] args) {
Connection connect = null;
Statement statement = null;
ResultSet resultSet = null;

try {
//第一步:注冊驅動
//第一種方式:類加載(常用)
//Class.forName("oracle.jdbc.OracleDriver");

//第二種方式:利用Driver對象
Driver driver = new OracleDriver();
DriverManager.deregisterDriver(driver);

//第三種方式:利用系統參數 需在idea中配置program arguments為下面的參數
//-Djdbc.drivers = oracle.jdbc.OracleDriver



//第二步:獲取連接
//第一種方式:利用DriverManager(常用)
//connect = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:XE", "你的oracle數據庫用戶名", "用戶名密碼");

//第二種方式:直接使用Driver
Properties pro = new Properties();
pro.put("user", "你的oracle數據庫用戶名");
pro.put("password", "用戶名密碼");
connect = driver.connect("jdbc:oracle:thin:@localhost:1521:XE", pro);

//測試connect正確與否
System.out.println(connect);


//第三步:獲取執行sql語句對象
//第一種方式:statement
//statement = connect.createStatement();

//第二種方式:PreStatement
PreparedStatement preState = connect.prepareStatement("select * from tb1_dept where id = ?");


//第四步:執行sql語句
//第一種方式:
//resultSet = statement.executeQuery("select * from tb1_dept");

//第二種方式:
preState.setInt(1, 2);//1是指sql語句中第一個?, 2是指第一個?的values值
//resultSet = preState.executeQuery(); //執行查詢語句
//查詢任何語句,如果有結果集,返回true,沒有的話返回false,注意如果是插入一條數據的話,雖然是沒有結果集,返回false,但是卻能成功的插入一條數據
boolean execute = preState.execute();
System.out.println(execute);

//第五步:處理結果集
while (resultSet.next())
{
int id = resultSet.getInt("id");
String name = resultSet.getString("name");
String city = resultSet.getString("city");
System.out.println(id+" "+name+" "+city); //打印輸出結果集
}
} catch (Exception e) {
e.printStackTrace();
}finally {
//第六步:關閉資源
try {
if (resultSet!=null) resultSet.close();
if (statement!=null) statement.close();
if (connect!=null) connect.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}

注解:

1、 第一步:注冊驅動 中的第三種方法 利用系統參數 需在idea中配置program arguments為下面的參數

這里我說一下怎么在IDEA中的配置方式吧

這里寫圖片描述

這里寫圖片描述

運行截圖:

這里寫圖片描述

OK !

下篇文章將寫 JDBC 的封裝。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM