(九)JDBC操作技术

2008-02-19 – 17:34 - 271 views

动态WEB的最大特点:可以操作数据库

  • JSP是通过JDBC(Java DataBase Connectivity)技术操作数据库的
  • 使用数据库之后可以发现,对数据的处理由数据库管理系统(DBMS)去完成,而程序只是将需要的数据进行显示

JDBC本身是JAVA连接数据库的一个标准,是JAVA操作数据库的方法,是SUN提供的,而微软操作数据库的方法是ODBC

JDBC 1.0:

  • 分类:
    1. JDBC-ODBC Bridge(JDBC-ODBC桥接方式):因为性能较差,在开发中不采用
    2. JDBC-native Driver Bridge:驱动有个数据库生产厂家提供
    3. JDBC-network Bridge
  • JDBC-ODBC:
    • JDBC-ODBC是在JDK中由SUN本身开发出来的一套数据访问操作,在JDBC-ODBC桥接中它的各种操作API都是最新的,但是性能不高
    • ODBC的基本原理
      • 通过一个数据源名称 ---> 数据库
      • 为数据库起了一个别名 ---> 程序通过别名访问数据库
      • 即:程序只认别名不认具体的数据库
  • 常用接口:
    1. 使用java.sql包
    2. 常用接口:--DriverManager --Connection --Statement --PreparedStatement --ResultSet
  • **利用JDBC开发WEB数据库应用框架
    1. 装入JDBC驱动程序
    2. 创建与数据库的连接
    3. 创建语句对象
    4. 利用语句对象执行SQL语句得到结果
    5. 处理结果
    6. JDBC应用结束,关闭各项操作
  • **JDBC具体使用--各条对应上面框架各条
    1. 通过Class.forName("XX"); eg.Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    2. Connection conn = DriverManager.getConnection(DBURL,USER,PASSWORD);
    3. 创建对象
      • 使用statement对象:Statement stmt = conn.createStatement();
      • 使用PreparedStatement对象:PreparedStatement pstmt = conn.PrepareStatement();
    4. 执行SQL语句返回ResultSet实例化对象
      • 查询数据库:stmt.ececuteQuery(sql);
        • 包括SELECT
      • 更新数据库:stmt.ececuteUpdate(sql);
        • 包括DELETE、INSERT、UPDATE
    5. 结果集ResultSet的处理
      • 使用getXXX();方法可以得到不同类型的结果值(参数可以是字段或编号)
      • next()方法可以使游标移动到下一条记录
    6. 数据库在每次使用之后都必要关闭,关闭数据库操作的顺序与打开数据库操作的顺序相反
  • PreparedStatement--Statement的子接口
    • 引入原因:当Statement所需要的SQL语句中包含“'”,会造成数据输入的不正确
    • 建议:在开发中尽量不去使用Statement对象,而去使用PreparedStatement操作数据库

JDBC 2.0新功能:

  1. ResultSet对象中的光标可以自由上下滚动
    • TYPE_FORWORD_ONLY:与JDBC1.0没有区别
    • TYPE_SCROLL_SENSITIVE:可以上下滚动,不能取得结果集改变的值
    • TYPE_SCROLL_INSENSITIVE:可以上下滚动,能够取得结果集改变的值
  2. 直接使用结果集操作
    1. 更新数据:rs.updateRow();
    2. 删除数据:rs.deleteRow();
  3. 批处理(Batch)
    1. JDBC2.0提供批处理操作,可以让一个Statement同时执行多个SQL语句,以提高性能
    2. 事务处理
      • 事务:在数据库批处理操作时,要么全部执行成功,要么全部失败
      • 这样做可以保证数据的完整性20080219001649853

您喜欢本文吗?即刻订阅"Alex's Blog",精彩文章不再错过!点击下列按钮收藏本文.

 

« 今天买了个U盘 JDBC连接Mysql数据库 »

发表回复