oracle的sys用户怎么通过jdbc连接
来源:互联网 发布:ubuntu开机自启动程序 编辑:程序博客网 时间:2024/05/17 09:39
转自:http://jamesq.bokee.com/1263981.html
经过GOOGLE 总算知道了如何在JDBC中使用SYSDBA角色连接ORACLE数据库
在DriverManager.getConnection通过Properties 设置连接的defaultRowPrefetch,nternal_logon 等信息。
// -----------------------------------------------------------------------------// ConnectionOptions.java// -----------------------------------------------------------------------------import java.sql.DriverManager;import java.sql.Connection;import java.sql.Statement;import java.sql.ResultSet;import java.sql.SQLException;import java.util.Properties;/*** -----------------------------------------------------------------------------* The following class provides an example of using jdbc to connect to an* Oracle database using several advanced options. For example, one of the most* used option is connecting to a database as SYSDBA. The following table* contains * * Connection Properties Recognized by Oracle jdbc Drivers * -------------------------------------------------------* Name Short Name Type Description * ------------------- ---------- -------- -----------------------------------* user n/a String The user name for logging into the* database.* password n/a String The password for logging into the* database.* database server String The connect string for the database.* internal_logon n/a String A role, such as SYSDBA or SYSOPER,* that allows you to log on as SYS.* defaultRowPrefetch prefetch String (containing integer value) * The default number of rows to* prefetch from the server.* (default value is "10") * remarksReporting remarks String (containing boolean value) * "true" if getTables() and * getColumns() should report * TABLE_REMARKS; equivalent to using * setRemarksReporting().* (default value is "false") * defaultBatchValue batchvalue String (containing integer value) * The default batch value that triggers* an execution request.* (default value is "10") * includeSynonyms synonyms String (containing boolean value)* "true" to include column information * from predefined "synonym" SQL * entities when you execute a * DataBaseMetaData getColumns() call; * equivalent to connection * setIncludeSynonyms() call.* (default value is "false") * * -----------------------------------------------------------------------------*/public class ConnectionOptions { final static String driverClass = "oracle.jdbc.driver.OracleDriver"; final static String connectionURL = "jdbc:oracle:thin:@localhost:1521:TRUESRC"; final static String userID = "scott"; final static String userPassword = "tiger"; Connection con = null; /** * Construct a QueryExample object. This constructor will create an Oracle * database connection. */ public ConnectionOptions() { Properties conProps = new Properties(); conProps.put("user", userID); conProps.put("password", userPassword); conProps.put("defaultRowPrefetch", "15"); conProps.put("internal_logon", "sysdba"); try { System.out.print(" Loading jdbc Driver -> " + driverClass + "n"); Class.forName(driverClass).newInstance(); System.out.print(" Connecting to -> " + connectionURL + "n"); this.con = DriverManager.getConnection(connectionURL, conProps); System.out.print(" Connected as -> " + userID + "n"); } catch (ClassNotFoundException e) { e.printStackTrace(); System.exit(1); } catch (InstantiationException e) { e.printStackTrace(); System.exit(1); } catch (IllegalAccessException e) { e.printStackTrace(); System.exit(1); } catch (SQLException e) { e.printStackTrace(); System.exit(1); } } /** * Method to check which database user we are logged in as */ public void performUserQuery() { Statement stmt = null; ResultSet rset = null; String queryString = "SELECT user, TO_CHAR(sysdate, 'DD-MON-YYYY HH24:MI:SS') " + "FROM dual"; try { System.out.print(" Creating Statement...n"); stmt = con.createStatement (); System.out.print(" Opening ResultsSet...n"); rset = stmt.executeQuery(queryString); rset.next(); System.out.println(" Database User -> " + rset.getString(1)); System.out.println(" Date / Time -> " + rset.getString(2)); System.out.println(); System.out.print(" Closing ResultSet...n"); rset.close(); System.out.print(" Closing Statement...n"); stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } /** * Close down Oracle connection. */ public void closeConnection() { try { System.out.print(" Closing Connection...n"); con.close(); } catch (SQLException e) { e.printStackTrace(); } } /** * Sole entry point to the class and application. * @param args Array of String arguments. */ public static void main(String[] args) { ConnectionOptions co = new ConnectionOptions(); co.performUserQuery(); co.closeConnection(); }}
- oracle的sys用户怎么通过jdbc连接
- 最近学习了如何以oracle的sys用户怎么通过jdbc连接
- 通过JDBC连接oracle数据库的十大技
- jdbc怎么连接oracle数据库?
- pb通过jdbc连接oracle
- pb通过jdbc连接oracle
- 通过JDBC连接Oracle数据库
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- 通过JDBC连接Oracle数据库的十大技巧
- 通过JDBC连接oracle数据库的十大技巧
- hash_map string key 忽略大小写
- 常用正则表达式集锦
- 最新发布Windows 8 Consumer Preview ISO images 预览版(中文)
- 19个非常有用的Javascript类库
- 设置myeclipse新建jsp文件默认编码为UTF-8
- oracle的sys用户怎么通过jdbc连接
- SNMP用VC++6.0实现的方法_VC技术_C语言教程(本文来自21视频教程网C语言频道)
- MotionEvent中getX()和getRawX()的区别
- PRML Chapter 2. Probability Distributions
- Django Admin 模块探究
- 记几个实用的测试website和web开发
- 得到“恒”标志
- mac系统截屏的快捷键
- NcPaint重绘非客户区