• JDBC的事务处理 JDBC事务处理 JDBC教程


    JDBC的事务基本知识

    事务的定义:一个事务是由一条或多条对数据库操作的sql语句所组成的一个不可分割的工作单元,只有当事务中的所有操作都正常执行后,整个事务才会提交给数据库。

    结束事务的操作:commit()/rollback()。commit表示对事务的提交,rollback表示对事务的回滚,这两种方法都处于java.sql.Connection类中。

    Q:通过什么方法保持对数据库的多次操作后,数据仍然保持一致?

    A:调用setAutoCommit(false)来控制防止自动提交,然后就可以把多个数据库的操作当成一个事物,在操作完成后调用commit()提交,如果中途出现问题,可以到用rollback()达到回滚的目的。

    JDBC的事务隔离:

    为了解决“多个线程请求相同的数据”的问题,事务之间会用锁相互隔离开来。现在不同的数据库支持不同的锁。JDBC API支持不同类型的事务,它们由Connection对象指派的。

    JDBC支持以下5种事务隔离级别:

    TRANSACTION_NONE JDB。不支持事务 TRANSACTION_READ_UNCOMMITTED。未提交读。说明在提交一个事物前一个事物可以看到另一个事务的变化。这样读“脏”数据、不可重复读和虚读都是允许的。 TRANSACTION_READ_COMMITTED。已提交读。说明读取为提交的数据是不允许的。这个级别仍然允许不可重复读和虚读。 TRANSACTION_REPEATABLE_READ。可重复读。虚读会出现。 TRANSACTION_REPEATABLE。可序列化。都不允许。

    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。说白了,它用于直接调用 SQL 命令。

    主要步骤:

    1.加载JDBC驱动程序
    2.建立于数据库的连接
    3.创建一个Statement,添加相关参数
    4.执行SQL语句
    5.处理执行结果
    6.关闭JDBC的对象 几个重要的类:
    (1)
    public class DriverManager extends Object
    管理一组 JDBC 驱动程序的基本服务。
    主要方法是:
    public static Connection getConnection(String url,String user,String password)throws SQLException
    试图建立到给定数据库 URL 的连接。DriverManager 试图从已注册的 JDBC 驱动程序集中选择一个适当的驱动程序。
    (2)
    public interface PreparedStatement extends Statement
    表示预编译的 SQL 语句的对象。 SQL 语句被预编译并存储在PreparedStatement对象中。然后可以使用此对象多次高效地执行该语句。 与Statement接口相比,Statement用于执行静态 SQL 语句并返回它所生成结果的对象。
    主要方法是:
    1. void setObject(int parameterIndex,Object x) throws SQLException
    使用给定对象设置指定参数的值,其实就是为SQL语句占位符的设定实际参数。

    2. intexecuteUpdate() throws SQLException

    在此 PreparedStatement 对象中执行 SQL 语句,该语句必须是一个 SQL 数据操作语言(Data Manipulation Language,DML)语句,比如 INSERT、UPDATE 或 DELETE 语句;或者是无返回内容的 SQL 语句,比如 DDL 语句。
    返回:
    (1) SQL 数据操作语言 (DML) 语句的行数 (2) 对于无返回内容的 SQL 语句,返回 0
    3. ResultSet executeQuery() throws SQLException
    在此 PreparedStatement 对象中执行 SQL 查询,并返回该查询生成的 ResultSet 对象。
    返回:
    包含该查询生成的数据的 ResultSet 对象;不会返回 null
    (3)
    留意执行executeUpdate()和executeQuery()方法返回的值发现executeQuery()返回的是一个结果集对象。
    public interface ResultSet extends Wrapper
    表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。
    主要方法是:
    1. ResultSetMetaData getMetaData() throws SQLException 获取此ResultSet对象的列的编号、类型和属性。
    而ResultSetMetaData的主要方法就是 int getColumnCount() 返回此 ResultSet 对象中的列数; String getColumnName(int column) 获取指定列的名称。
    2. Object getObject(int columnIndex) throws SQLException 以 Java 编程语言中 Object 的形式获取此 ResultSet 对象的当前行中指定列的值。

  • 相关阅读:
    IDEA搭建普通java项目
    反射的学习
    解决Eclipse中文文档注释错位-处女座的悲哀!
    maven私服的搭建
    Springboot简介01
    git初识
    Servlet学习系列1
    搭建和启动javaWeb项目
    IDEA快捷键使用说明
    1.6 比较、掩码和布尔逻辑
  • 原文地址:https://www.cnblogs.com/2881064178dinfeng/p/6963888.html
Copyright © 2020-2023  润新知