- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在查看有关事务的 ACID 属性,并在不同站点上遇到了以下声明ACID 是事务保证的四个属性的首字母缩写:原子性、一致性、隔离性和持久性。
**我的问题专门针对这个短语。
guaranteed by transactions
**。根据我的经验,这些属性不受自动交易。但作为 Java 开发人员,我们需要确保满足这些属性标准。
让我们来看看每个属性:-
原子性:- 假设当我们创建客户时,帐户也应该创建,因为这是强制性的。所以现在在交易期间客户在帐户创建过程中创建时出现一些异常。所以开发人员现在可以采取两种方式:要么他回滚完成交易(在这种情况下满足原子性)或者他提交交易所以客户将被创建但不是帐户(这违反了原子性)。所以责任在于开发者?
一致性:- 同样的原因也适用于一致性
隔离:- 根据定义,隔离使事务的执行不受其他进程或事务的干扰。
但这是在我们将隔离级别设置为可序列化时实现的。否则在另一种情况下,如读取已提交或读取未提交更改对其他交易可见。因此,责任在于开发人员使其真正与 Serializable 隔离?
持久性:- 如果我们提交事务,那么即使应用程序崩溃,它也应该在应用程序重新启动时提交。不确定它是否需要由开发人员或数据库供应商/交易来处理?
因此,根据我的理解,这些 ACID 属性不能自动得到保证;相反,我们作为开发人员应该实现它们。请告诉我以上对每一点的理解是否正确?如果你们能对每一点进行回复,我们将不胜感激(是/否也可以。
根据我的理解,已提交读应该是大多数应用程序中最符合逻辑的隔离级别,尽管它也取决于要求。
最佳答案
事务或多或少保证了 ACID:
1) 原子性。事务保证进行所有更改或不进行任何更改。但是需要手动设置一个事务的开始和结束,手动commit或者rollback。根据您使用的技术(EJB...),事务是容器管理的,将开始和结束设置为您正在创建的整个“方法”。您可以通过配置来控制调用的方法是需要新事务还是现有事务,没有事务...
2) 一致性。由原子性保证。
3) 隔离。您必须定义应用程序需要的隔离级别。默认值根据数据库、容器定义...最常见的是 READ COMMITTED。小心使用锁,因为它可能会导致死锁,具体取决于您的逻辑和隔离级别。
4) 耐用性。完全由数据库管理。如果你的提交没有错误地执行,几乎所有的数据库都能保证更改的持久性,但有些情况可能会导致无法保证(写入磁盘会缓存在内存中并稍后刷新......)
一般情况下,你应该了解事务并在代码声明的容器中配置它的启动和结束(提交,回滚)。
关于java - 确保事务的 ACID 属性的责任在哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7379064/
我有以下对象: dog = { location: { x: 52.1089, y: 16.2323 }, f: function(message) { alert
在 TSQL 中,如果我要搜索有效的 .com 电子邮件地址,我需要确保有一个 @ 符号,它以 .com 结尾,并且在 @ 前后至少有一个字符。 SELECT * FROM CUSTOMER WHER
我正在尝试准备一个信用卡交易列表,以便在 Excel 2010 中进行透视和进一步分析(满足个人需求)。问题是我的银行机构没有遵循标准的日期格式,所以有时日期会显示为 Jun. 1, 2013 , 有
看来您不能在 riak 中进行交易。如何确保数据正确? 假设我们要插入评论。在 redis 我会做 commentId=incr commentCount multi SET comment_post
对于下面给定的模式,是否可以确保至少一个属性包含一个值(即 minLength 为 1): { "$schema": "http://json-schema.org/draft-04/sche
我计划在 Haxe 的一个子集中编写 Haxe 库,这些库将编译为每种 Haxe 目标语言。有什么方法可以验证 Haxe 程序是否可以编译为所有目标语言,是否可以在不手动测试每个目标平台上的编译代码的
如果浏览器窗口未聚焦,则当前页面上的所有 webdriver 标识都失败。 如何使用 webdriver 使浏览器成为焦点? 最佳答案 ((JavascriptExecutor) webDriver)
我从这样的 HTML GET 请求中获取图像链接... www.example.com?image=www.anotherdomain.com/image.jpg if (isset($_GET['i
我有一个 eunit 测试,它生成一个唯一的节点名称并开始分发: {A,B,C} = now(), Nodename = list_to_atom(lists:flatten(io_lib:forma
我正在完成我的 iPhone 应用程序。我只是担心我们的网络服务器级别的安全性。数据通过网络服务被传送到 iPhone 应用程序。 我可以在网络服务上采取哪些安全措施,以免受到攻击? 谢谢 最佳答案
我正在编写一个应用程序,该应用程序启动一个运行简单 Web 服务器的子进程。我正在使用 NSTask 并通过管道与其进行通信,一切看起来或多或少都很好。但是,如果我的程序崩溃,子进程将保持事件状态,并
我有一些应用程序,我调用 ShowMessage('Complete!');在长时间操作结束时。 大多数时候,这效果很好,但每隔一段时间,消息对话框就会显示在主窗体后面。 有什么方法可以确保 Show
我通过将消息插入集合并让模板使用 {{#each}} 打印出集合来创建一个简单的聊天。 我不太熟悉安全性,但是有没有办法让它符合 EFF 规定? https://www.eff.org/secure-
我有一个商店,我想在其中正确管理 id。假设我有以下帖子存储: type Post = { id: number; title: string; body?: string; } type
我有一个使用 ajax post 方法和数据表的程序。经过几周的摆弄,我确定我根本不明白 javascript 是如何工作的。这是我的 JavaScript: $('#SaveTimeSheet').
我有一个系统,如果从 Azure 服务总线丢失消息将是一场灾难,也就是说,数据将永远丢失,并且没有实际方法可以在不造成重大中断的情况下修复损坏。 在这种情况下我可以完全依赖 ASB 吗? (即使它
如何确保 scalatest 测试不会并行运行?在 0.12 之前,我有一个 sbt 设置: parallelExecution in Test := false 新版本引入了一些复杂的机制。这种更简
我的端点有两个如下所示的 promise : request.post({ url: url, json: smsSTART, header
简短版本 当 ui-router 转换到新 View 时(以我不完全理解的方式使用 ngAnimate),它会添加类 ng-leave 和 ng-leave-active 到当前 View 。它还将类
目前正在努力寻找验证 2 个表的方法(有效地验证表 A 的大量行) 我有两张 table 表A ID A B C 表格匹配 ID Number A 1 A 2 A 9 B 1
我是一名优秀的程序员,十分优秀!