JDBC原理

JDBC接口及数据库厂商实现

类型 类名
驱动管理 DriverManager
连接接口 Connection
DatabaseMetaData
语句对象接口 Statement
PreparedStatement
CallableStatement
结果集接口 ResultSet
ResultSetMetaData

工作原理

  • 加载驱动,建立连接:DriverManager
  • 创建语句对象:Statement
  • 执行SQL语句:一个字符串,通过Statement执行
  • 处理结果集:只有查询语句才有结果集
  • 关闭连接

Driver接口及驱动类加载

驱动类加载方式:
(Oracle)Class.forName("oracle.jdbc.driver.OracleDriver");
(MySQL)
Class.forName("com.mysql.jdbc.Driver");

Connection接口

//Oracle格式
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","openlab","open123");
//三个参数分别是url,用户名,密码
//jdbc:oracle:thin:@HOST:PORT:数据库实例名

//MySQL格式
Connection conn= DriverManager.getConnection("jdbc:mysql://localhost:3306/myDB?user=soft&password=soft1234&useSSL=false&useUnicod 
e=true&characterEncoding=8859_1"); 
//jdbc:mysql://HOST:PORT/数据库名

Statement接口

Statement stmt = conn.createStatement();
  • boolean flag = stmt.execute(sql);
  • ResultSet rs = stmt.executeQuery(sql);
  • int flag = stmt.executeUpdate(sql);

execute执行的语句通常是DDL语句。

executeQuery通常用于执行查询语句。

executeUpdate通常用于DML操作。返回值是影响的数据条数。

ResultSet接口

执行查询SQL语句后返回的结果集,由ResultSet接口接收。

常用处理方式:遍历/判断是否有结果

String sql = "select * from emp";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()) {
    System.out.println(rs.getInt("empno") + "," + rs.getString("ename"));
  • 查询的一系列结果存放在ResultSet对象的一系列行中
  • ResultSet对象的最初位置在行首
  • ResultSet.next()方法用来在行间移动,一定要调用next确保有数据再获取字段的值
  • ResultSet.getXXX()方法用来取得字段的内容

原文: https://www.jianshu.com/p/c65d52f431fc

posted @ 2020-03-18 20:18  sunleejon  阅读(106)  评论(0编辑  收藏  举报