Ⅰ 通過JDBC連接oracle資料庫的幾個技巧
java資料庫連接(jdbc)api是一系列能夠讓java編程人員訪問資料庫的介面,各個開發商的介面並不完全相同。以下是一些技巧,這些技巧能夠使我們更好地發揮系統的性能和實現更多的功能。1、在客戶端軟體開發中使用thin驅動程序
在開發java軟體方面,oracle的資料庫提供了四種類型的驅動程序,二種用於應用軟體、applets、servlets等客戶端軟體,另外二種用於資料庫中的java存儲過程等伺服器端軟體。在客戶機端軟體的開發中,我們可以選擇oci驅動程序或thin驅動程序。oci驅動程序利用java本地化介面(jni),通過oracle客戶端軟體與資料庫進行通訊。thin驅動程序是純java驅動程序,它直接與資料庫進行通訊。為了獲得最高的性能嫌塵,oracle建議在客戶端軟體的開發中使用oci驅動程序,這似乎是正確的。但我建議使用thin驅動程序,因為通過多次測試發現,在通常情況下,thin驅動程序的性能都超過了oci驅動程序。
2、關閉自動提交功能,提高系統性能
在第一次建立與資料庫的連接時,在預設情況下,連接是在自動提交模式下的。為了獲得更好的性能,可以通過調用帶布爾值false參數的connection類的setautocommit()方法關閉自動提交功能,如下所示:
conn.setautocommit(false);
值得注意的是,一旦關閉了自動提交功能,我們就需要通過調用connection類的commit()和rollback()方法來人工的方式對事務進行管理。
3、在動態sql或有時間限制的命令中使用statement對象
在執行sql命令時,我們有二種選舉明擇:可以使用preparedstatement對象,也可以使用statement對象。無論多少次地使用同一個sql命令,preparedstatement都只對它解析和編譯一次。當使用statement對象時,每次執行一個sql命令時,都會對它進行解析和芹答禪編譯。這可能會使你認為,使用preparedstatement對象比使用statement對象的速度更快。然而,我進行的測試表明,在客戶端軟體中,情況並非如此。因此,在有時間限制的sql操作中,除非成批地處理sql命令,我們應當考慮使用statement對象。
此外,使用statement對象也使得編寫動態sql命令更加簡單,因為我們可以將字元串連接在一起,建立一個有效的sql命令。因此,我認為,statement對象可以使動態sql命令的創建和執行變得更加簡單。
4、利用helper函數對動態sql命令進行格式化
在創建使用statement對象執行的動態sql命令時,我們需要處理一些格式化方面的問題。例如,如果我們想創建一個將名字o'reilly插入表中的sql命令,則必須使用二個相連的“''”號替換o'reilly中的“'”號。完成這些工作的最好的方法是創建一個完成替換操作的helper方法,然後在連接字元串心服用公式表達一個sql命令時,使用創建的helper方法。與此類似的是,我們可以讓helper方法接受一個date型的值,然後讓它輸出基於oracle的to_date()函數的字元串表達式。
5、利用preparedstatement對象提高資料庫的總體效率
在使用preparedstatement對象執行sql命令時,命令被資料庫進行解析和編譯,然後被放到命令緩沖區。然後,每當執行同一個preparedstatement對象時,它就會被再解析一次,但不會被再次編譯。在緩沖區中可以發現預編譯的命令,並且可以重新使用。在有大量用戶的企業級應用軟體中,經常會重復執行相同的sql命令,使用preparedstatement對象帶來的編譯次數的減少能夠提高資料庫的總體性能。如果不是在客戶端創建、預備、執行preparedstatement任務需要的時間長於statement任務,我會建議在除動態sql命令之外的所有情況下使用preparedstatement對象。
6、在成批處理重復的插入或更新操作中使用preparedstatement對象
如果成批地處理插入和更新操作,就能夠顯著地減少它們所需要的時間。oracle提供的statement和 callablestatement並不真正地支持批處理,只有preparedstatement對象才真正地支持批處理。我們可以使用addbatch()和executebatch()方法選擇標準的jdbc批處理,或者通過利用preparedstatement對象的setexecutebatch()方法和標準的executeupdate()方法選擇速度更快的oracle專有的方法。要使用oracle專有的批處理機制,可以以如下所示的方式調用setexecutebatch():
preparedstatement pstmt3d null;
try {
((oraclepreparedstatement)
pstmt).setexecutebatch(30);
...
pstmt.executeupdate();
}
調用setexecutebatch()時指定的值是一個上限,當達到該值時,就會自動地引發sql命令執行,標準的executeupdate()方法就會被作為批處理送到資料庫中。我們可以通過調用preparedstatement類的sendbatch()方法隨時傳輸批處理任務。
7、使用oracle locator方法插入、更新大對象(lob)
oracle的preparedstatement類不完全支持blob和clob等大對象的處理,尤其是thin驅動程序不支持利用preparedstatement對象的setobject()和setbinarystream()方法設置blob的值,也不支持利用setcharacterstream()方法設置clob的值。只有locator本身中的方法才能夠從資料庫中獲取lob類型的值。可以使用preparedstatement對象插入或更新lob,但需要使用locator才能獲取lob的值。由於存在這二個問題,因此,我建議使用locator的方法來插入、更新或獲取lob的值。
8、使用sql92語法調用存儲過程
在調用存儲過程時,我們可以使用sql92或oracle pl/sql,由於使用oracle pl/sql並沒有什麼實際的好處,而且會給以後維護你的應用程序的開發人員帶來麻煩,因此,我建議在調用存儲過程時使用sql92。
9、使用object sql將對象模式轉移到資料庫中
既然可以將oracle的資料庫作為一種面向對象的資料庫來使用,就可以考慮將應用程序中的面向對象模式轉到資料庫中。目前的方法是創建java bean作為偽裝的資料庫對象,將它們的屬性映射到關系表中,然後在這些bean中添加方法。盡管這樣作在java中沒有什麼問題,但由於操作都是在資料庫之外進行的,因此其他訪問資料庫的應用軟體無法利用對象模式。如果利用oracle的面向對象的技術,可以通過創建一個新的資料庫對象類型在資料庫中模仿其數據和操作,然後使用jpublisher等工具生成自己的java bean類。如果使用這種方式,不但java應用程序可以使用應用軟體的對象模式,其他需要共享你的應用中的數據和操作的應用軟體也可以使用應用軟體中的對象模式。
Ⅱ 請寫出一段JDBC訪問Oracle資料庫的代碼
實現思路:就是通過ojdbc.jar中提供的方法,直接連接資料庫即可,固定代碼寫法如下:
importjava.sql.Connection;
importjava.sql.DriverManager;
importjava.sql.ResultSet;
importjava.sql.Statement;
publicclassJDBCTest{
publicstaticvoidmain(String[]args)throwsException{
//1.載入驅動
//Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
//Class.forName("com.mysql.jdbc.Driver");
Class.forName("oracle.jdbc.driver.OracleDriver");
//2.創建資料庫連接對象
//Connectionconn=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;databaseName=db","sa","sqlpass");
//Connectionconn=DriverManager.getConnection("jdbc:mysql://localhost:3306/db?useUnicode=true&characterEncoding=UTF-8","root","123456");
Connectionconn=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","scott","Oracle123");
//3.創建資料庫命令執行對象
Statementstmt=conn.createStatement();
// PreparedStatementps=conn.prepareStatement("select*fromt_user");
//4.執行資料庫命令
ResultSetrs=stmt.executeQuery("select*fromt_user");
// ResultSetrs=ps.executeQuery();
//5.處理執行結果
while(rs.next()){
intid=rs.getInt("id");
Stringusername=rs.getString("username");
Stringpassword=rs.getString("password");
System.out.println(id+" "+username+" "+password);
}
//6.釋放資料庫資源
if(rs!=null){
rs.close();
}
// if(ps!=null){
// ps.close();
// }
if(stmt!=null){
stmt.close();
}
if(conn!=null){
conn.close();
}
}
}
Ⅲ 怎樣利用JDBC連接並操作Oracle資料庫
文件用:ojdbc6.jar
/**
*一個非常標準的連接Oracle資料庫的示例代碼
*/
publicvoidtestOracle()
{
Connectioncon=null;//創建一個資料庫連接
PreparedStatementpre=null;//創建預編譯語句對象,一般都是用這個而不用Statement
ResultSetresult=null;//創建一個結果集對象
try
{
Class.forName("oracle.jdbc.driver.OracleDriver");//載入Oracle驅動程序
System.out.println("開始嘗試連接資料庫!");
Stringurl="jdbc:oracle:thin:@127.0.0.1:1521:XE";//127.0.0.1是本機地址,XE是精簡版Oracle的默認資料庫的SID
襲升拍滲老//如果是服務名,則用Stringurl="jdbc:oracle:thin:@127.0.0.1:1521/ORCL
Stringuser="system";//用戶名,系統默認的賬戶名
Stringpassword="147";//你安裝時選設置的密碼
con=DriverManager.getConnection(url,user,password);//獲取連接
System.out.println("連接成功!");
Stringsql="select*fromstudentwherename=?";//預編譯語句,「?」代表參數
pre=con.prepareStatement(sql);//實例化預編譯語句
pre.setString(1,"劉顯安");//設置參數,前面的1表示參數的索引,而不是表中列名的索引
result=pre.executeQuery();//執行查詢,注意括弧中不需要再加參數
while(result.next())
//當結果集不為空時
System.out.println("學號:"+result.getInt("id")+"姓名:"
+result.getString("name"));
喊棚}
catch(Exceptione)
{
e.printStackTrace();
}
finally
{
try
{
//逐一將上面的幾個對象關閉,因為不關閉的話會影響性能、並且佔用資源
//注意關閉的順序,最後使用的最先關閉
if(result!=null)
result.close();
if(pre!=null)
pre.close();
if(con!=null)
con.close();
System.out.println("資料庫連接已關閉!");
}
catch(Exceptione)
{
e.printStackTrace();
}
}
}