JDBC基础(3)_JDBC 连接 Oracle 数据库的具体流程

JDBC

JDBC 连接数据库的具体流程

● 引入数据库的驱动 jar 包

● 获取连接

  • 获取连接需要两步,一是使用 DriverManager 来注册驱动,二是使用 DriverManager 来获取 Connection 对象。
  • 注册驱动
    注册驱动就只有一句话:
    Class.forName(“oracle.jdbc.OracleDriver”)
    
  • 获取连接
  • 获取连接的也只有一句代码:
    DriverManager.getConnection(url,username,password)	
    
    ① username 和 password 是登录数据库的用户名和密码
    ② url 相对复杂一点,它是用来找到要连接数据库 “网址”,就好比你要浏览器中查找百度时,也需要提供一个 url
  • oracle 的url:
    jdbc:oracle:thin:@127.0.0.1:1521:orcl	
    
    JDBC 规定 url 的格式由三部分组成,每个部分中间使用冒号分隔。
    ① 第一部分是 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 stmt = con.createStatement();
    
    Statement 是用来向数据库发送要执行的 SQL 语句的!

● 发送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.next();//光标移动到下一行
    rs.getInt(1);//获取第一行第一列的数据
    
    当你使用 rs.getInt(1) 方法时,你必须可以肯定第 1 列的数据类型就是int类型,如果你不能肯定,那么最好使用 rs.getObject(1)。在 ResultSet 类中提供了一系列的 getXXX() 方法,比较常用的方法有:
    Object getObject(int col)
    String getString(int col)
    int getInt(int col)
    double getDouble(int col)
    
    更多请参见 API
    JDBC基础(3)_JDBC 连接 Oracle 数据库的具体流程

● 关闭资源

  • 与 IO 流一样,使用后的东西都需要关闭!关闭的顺序是先得到的后关闭,后得到的先关闭。
    rs.close();
    stmt.close();
    con.close(); 
    

● 示例见后两讲

如有错误,欢迎指正!