Chinaunix首页 | 论坛 | 博客
  • 博客访问: 104673143
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-04-01 14:33:42

来源:赛迪网    作者:20936

1.首先,在D:\oracle\ora92\jdbc\lib下(Oracle安装目录)有许多.jar包文件,大家必须把其中的ojdbc14.jar复制到你的项目中,然后右击此文件,继续选择“构建路径” 选择其中的“导入”选项,现在就可以打开并使用包下的类文件了。(注释:你也可以把该驱动程序放在classpath环境变量中,其他类包的设置也与此类似)

2.继续加载及注册驱动程序

class.forname("oracle.jdbc.driver.oracledriver");

加载驱动程序后,一般会建立一个driver对象,并经由调用drivermanager.registerdriver()来自动注册此对象。

3.建立连接

drivermanager.getconnection("jdbc:oracle:thin:@localhost:1521:lc",name,pass);

其中jdbc url 的标准语法如下:

::

至此,我们可以发现具体分为三个部分:

◆protocol:主要通讯协议

◆subprotocol:次要的通讯协议,其驱动的名称

◆data source identifier:数据来源

如上例所示:

"jdbc:oracle:thin"是通讯协议,@后"为有效的主机地址,然后是端口号,默认的是:1521,然后是你的数据源,,就是用户名和口令,用下面的形式也可以:

connection con= drivermanager.getconnection("jdbc:oracle:thin:name/

pass@localhost:1521:lc");

返回一个connection 的对象con。

4.建立一个SQL陈述式对象

该例子是建立了个预制语句。

preparedstatement pstmt = con.preparestatement(sql语句);

也可以使用:

statement stmt=con.createstatement();

不同之处请大家查看帮助文档。

5.执行该语句

executeupdate(),executequery(),execute(),
 

使用方法请查帮助文档。

6.完成清理工作

然后关闭连接,完整的例子:

该类完成加载及连接,

import java.sql.connection;

import java.sql.drivermanager;

import java.sql.sqlexception;

public class dbconnection {

public static connection dbconn(string name,string pass)  {

connection c = null;

try {

class.forname("oracle.jdbc.driver.oracledriver");

} catch (classnotfoundexception e) {

e.printstacktrace();

}

try {

c =drivermanager.getconnection("jdbc:oracle:thin:@localhost:1521:sumoonbest",

name,pass);

} catch (sqlexception e1) {

e1.printstacktrace();

}

return c;

}

}

最后,此类完成发送语句,执行,清理。

import java.sql.*;

public class db extends dbconnection {

private static connection con = null; 

public static void main(string[] args) {    

try {     

con=  dbconn("sumoonbest","8848");    

if (con == null) {

system.out.print("连接失败");

system.exit(0);

}

string url = "delete from t_user where username=wang";

preparedstatement pres = conn.preparestatement(url);   

system.out.print(pres.executeupdate()) ;

}  

con.close();

} catch (exception e) {

e.printstacktrace();

}

}

}
阅读(273) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~