• 第五节 了解事物


    事务就是真实世界中的一些事件,比如银行事务,航班预定,资金汇寄等。

    事务是一组被当作一个单元执行的操作。它在执行时要么全部成功,要么全部失败。

    事务有四个属性,常称为ACID。原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。

      1.原子性:整个事务中的所有操作,要么全部完成,要么全部不完成,不可能停滞在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。

      2.一致性:在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。

      3.隔离性:隔离状态执行事务,使它们好像是系统在给定时间内执行的唯一操作。如果有两个事务,运行在相同的时间内,执行相同的功能,事务的隔离性将确保每一事务在系统中认为只有该事务在使用系统。这种属性有时称为串行化,为了防止事务操作间的混淆,必须串行化或序列化请求,使得在同一时间仅有一个请求用于同一数据。

      4.持久性:在事务完成以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。

    ADO.NET中简单的事务处理:

     using (SqlConnection conn = new SqlConnection(GetConnection()))
                {
                    conn.Open();
    
                    //启动一个事务
                    using (SqlTransaction transaction = conn.BeginTransaction())
                    {
                        using (SqlCommand cmd = conn.CreateCommand())
                        {
                            try
                            {
                                cmd.Transaction = transaction;  //为命令指定事务
    
                                cmd.CommandText = "INSERT INTO tb_user(UserId,UserName) VALUE('Id0002','Name0002');";
    
                                cmd.ExecuteNonQuery();
    
                                cmd.CommandText = "INSERT INTO tb_user(UserId,UserName) VALUE('Id0008','Name0008');";
    
                                cmd.ExecuteNonQuery();
    
                                transaction.Commit();   //事务提交
    
                                Response.Write("<script>alert('成功写入记录');</script>");
                            }
                            catch (Exception ex)
                            {
                                transaction.Rollback(); //事务回滚
    
                                Response.Write(ex.Message);
    
                                Response.Write("<script>alert('写入记录失败');</script>");
                            }
                        }
                    }
                }
  • 相关阅读:
    第150天:网页中插入百度地图方法(需要密钥)
    第149天:javascript中this的指向详解
    第148天:js+rem动态计算font-size的大小,适配各种手机设备
    第147天:web前端开发中的各种居中总结
    第146天:移动H5前端性能优化
    第145天:jQuery.touchSlider触屏满屏左右滚动幻灯片
    第144天:PS切图方法总结
    第143天:渐进增强和优雅降级之间的不同
    第142天:Size Marks下载安装和使用方法
    第141天:前端开发中浏览器兼容性问题总结(二)
  • 原文地址:https://www.cnblogs.com/shuibing/p/4157745.html
Copyright © 2020-2023  润新知