
使用thin连接
由于thin驱动都是纯Java代码,并且使用TCP/IP技术通过java的Socket连接上Oracle数据库,所以thin驱动是与平台无关的,你无需安装Oracle客户端,只需要下载一个thin驱动的jar包,并且将环境变量中的CLASS_PATH变量中加入thin驱动的路径就可以了。Thin驱动虽然与平台无关,也无需安装Oracle客户端,但是有一个致命的缺陷就是性能一般,达不到如OCI方式的企业级的要求。
另外,如果一个oracle数据库对应一台主机,可以使用thin连接;如果一个oracle数据库对应四五台主机(集群服务器),使用thin时,需要把tnsnames.ora文件中的相关数据库的整个连接字符串都拷贝下来,如此才能连接上oracle集群数据库。而这种方法也是和数位同事讨论并Google了大量资料后才发现的。之前我一直以为thin不支持集群数据库的方式。
文件用:ojdbc6.jar
/*** 一个非常标准的连接Oracle数据库的示例代码
*/
public void testOracle()
{
Connection con = null// 创建一个数据库连接
PreparedStatement pre = null// 创建预编译语句对象,一般都是用这个而不用Statement
ResultSet result = null// 创建一个结果集对象
try
{
Class.forName("oracle.jdbc.driver.OracleDriver")// 加载Oracle驱动程序
System.out.println("开始尝试连接数据库!")
String url = "jdbc:oracle:thin:@127.0.0.1:1521:XE"// 127.0.0.1是本机地址,XE是精简版Oracle的默认数据库的SID
// 如果是服务名,则用String url = "jdbc:oracle:thin:@127.0.0.1:1521/ORCL
String user = "system"// 用户名,系统默认的账户名
String password = "147"// 你安装时选设置的密码
con = DriverManager.getConnection(url, user, password)// 获取连接
System.out.println("连接成功!")
String sql = "select * from student where name=?"// 预编译语句,“?”代表参数
pre = con.prepareStatement(sql)// 实例化预编译语句
pre.setString(1, "刘显安")// 设置参数,前面的1表示参数的索引,而不是表中列名的索引
result = pre.executeQuery()// 执行查询,注意括号中不需要再加参数
while (result.next())
// 当结果集不为空时
System.out.println("学号:" + result.getInt("id") + "姓名:"
+ result.getString("name"))
}
catch (Exception e)
{
e.printStackTrace()
}
finally
{
try
{
// 逐一将上面的几个对象关闭,因为不关闭的话会影响性能、并且占用资源
// 注意关闭的顺序,最后使用的最先关闭
if (result != null)
result.close()
if (pre != null)
pre.close()
if (con != null)
con.close()
System.out.println("数据库连接已关闭!")
}
catch (Exception e)
{
e.printStackTrace()
}
}
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)