设为首页 加入收藏

TOP

JDBC编程-事务编程(四)(一)
2015-11-21 01:41:19 来源: 作者: 【 】 浏览:3
Tags:JDBC 编程 事务

事务的概念

事务的概念在我看来是指的是一组sql序列,这个序列是一块执行的单位,要么全部执行,要不全部执行,这样可以很好的对数据库进行并发控制。
因为数据库是多个用户都可以同时操作的,如果多个用户同时操作一个数据,就容易造成数据的不一致,所以事务作为并发控制的一个基本单位很有必要。

事务的特性

1.原子性:事务是一个完整的整体,所有的操作和数据都是一个整体。
2.一致性:事务的操作是一致性的。
3.隔离性:事务之间的操作是相互隔离的。
4.持久性:事务的操作是持久的,即使出现了错误也会完成。

事务的语句

BEGIN TRANSACTION
COMMIT TRANSACTION
ROLLBACK TRANSACTION

试验代码

public static Statement getStatement(){
        Statement st = null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            Connection conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/jsp_dbb", "root", "");
            st = (Statement) conn.createStatement();
        } catch (Exception e) {
            // TODO: handle exception
        }
        return st;
    }
    public static void insertUserData(){
        try {
            String sql = "INSERT INTO tbl_user(id,name,password,email)" +
                    "VALUES(10,'Tom','123456','tom@qq.com')";
            Statement st = getStatement();
            int count = st.executeUpdate(sql);
            System.out.println("插入了"+count+"行用户数据");
        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }
    }
    public static void insertAddressData(){
        try {
            String sql = "INSERT INTO tbl_address(id,city,country,user_id)" +
                    "VALUES(1,'shanghai','china,'10')";
            Statement st = getStatement();
            int count = st.executeUpdate(sql);
            System.out.println("插入了"+count+"行地址数据");
        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }
    }
    public static void main(String[] args) {
        insertUserData();
        insertAddressData();
    }

这段代码会报错,因为在tbl_address中已经有id = 1的数据了,具体如下图:

插入了1行用户数据
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '10')' at line 1
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:377)
    at com.mysql.jdbc.Util.getInstance(Util.java:360)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:978)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3887)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3823)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2435)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2582)
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2526)
    at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1618)
    at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1549)
    at liu.peng.jdbc.TransactionTest.insertAddressData(TransactionTest.java:37)
    at liu.peng.jdbc.TransactionTest.main(TransactionTest.java:46)

检查发现只是插入user表的数据,没有插入address表数据,造成数据不完整。

事务处理的应用

事务处理的核心代码就是
conn.setAutoCommit(false);
在执行完之后的提交。
conn.commit();
以及在捕获异常时候的回滚。
具体代码如下:

public static Connection getConnection(){
        Connection conn = null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/jsp_dbb", "root", "");
        } catch (Exception e) {
            // TODO: handle exception
        }
        return conn;
    }
    public static void insertUserData(Connection conn)throws SQLExc
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇一键导出excel 下一篇JDBC操作事务

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: