JDBC基础(3)_JDBC 连接 Oracle 数据库的具体流程
JDBC
JDBC 连接数据库的具体流程
● 引入数据库的驱动 jar 包
- Oracle:ojdbc6.jar,提取码:hahg 。
● 获取连接
- 获取连接需要两步,一是使用 DriverManager 来注册驱动,二是使用 DriverManager 来获取 Connection 对象。
- 注册驱动
注册驱动就只有一句话:Class.forName(“oracle.jdbc.OracleDriver”)
- 获取连接
- 获取连接的也只有一句代码:
① username 和 password 是登录数据库的用户名和密码DriverManager.getConnection(url,username,password)
② url 相对复杂一点,它是用来找到要连接数据库 “网址”,就好比你要浏览器中查找百度时,也需要提供一个 url - oracle 的url:
JDBC 规定 url 的格式由三部分组成,每个部分中间使用冒号分隔。jdbc:oracle:thin:@127.0.0.1:1521:orcl
① 第一部分是 jdbc,这是固定的;
② 第二部分是数据库名称,那么连接 oracle 数据库,第二部分当然是 oracle 了;
③ 第三部分是由数据库厂商规定的,我们需要了解每个数据库厂商的要求,oracle 的第三部分分别由数据库服务器的 IP 地址(localhost)、端口号(1521),以及 DATABASE 名称(orcl)组成。 - 获取连接的语句:
Connection con = DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl","username","password");
● 获取 Statement
- 在得到 Connectoin 之后,说明已经与数据库连接上了,下面是通过 Connection 获取 Statement 对象的代码:
Statement 是用来向数据库发送要执行的 SQL 语句的!Statement stmt = con.createStatement();
● 发送SQL增、删、改语句
- 示例:
// 定义 sql 插入语句 String sql = "insert into person(id,name,gender,birthday)values(personid.nextval,'魏宇轩','1',to_date('1997-09-23','yyyy-mm-dd'))"; // 定义 sql 更新语句 String sql = "update person t set t.gender = '2',t.birthday=to_date('2000-09-23','yyyy-mm-dd') where t.id=2"; // 定义 sql 删除语句 String sql = "delete person t where t.id=2"; // 创建 sql 执行对象 stmt = conn.createStatement(); // 执行查询 sql 并返回更新条数 int count = stmt.executeUpdate(sql);
- 其中 int 类型的返回值表示执行这条 SQL 语句所影响的行数,我们知道,对 insert 来说,最后只能影响一行,而 update 和 delete 可能会影响 0~n 行。
- 如果 SQL 语句执行失败,那么 executeUpdate() 会抛出一个 SQLException。
● 发送SQL查询语句
- 示例:
String sql = "select * from personr"; ResultSet rs = stmt.executeQuery(sql);
- 请注意,执行查询使用的不是 executeUpdate() 方法,而是 executeQuery() 方法。executeQuery() 方法返回的是 ResultSet,ResultSet 封装了查询结果,我们称之为结果集。
如果是查询读取结果集中的数据
- ResultSet 就是一张二维的表格,它内部有一个 “行光标”,光标默认的位置在 “第一行上方”,我们可以调用 rs 对象的 next() 方法把 “行光标” 向下移动一行,当第一次调用 next() 方法时,“行光标”就到了第一行记录的位置,这时就可以使用 ResultSet 提供的 getXXX(int col) 方法来获取指定列的数据了:
当你使用 rs.getInt(1) 方法时,你必须可以肯定第 1 列的数据类型就是int类型,如果你不能肯定,那么最好使用 rs.getObject(1)。在 ResultSet 类中提供了一系列的 getXXX() 方法,比较常用的方法有:rs.next();//光标移动到下一行 rs.getInt(1);//获取第一行第一列的数据
更多请参见 APIObject getObject(int col) String getString(int col) int getInt(int col) double getDouble(int col)
● 关闭资源
- 与 IO 流一样,使用后的东西都需要关闭!关闭的顺序是先得到的后关闭,后得到的先关闭。
rs.close(); stmt.close(); con.close();
● 示例见后两讲
如有错误,欢迎指正!