- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道用户名是否已在使用中,如果不是,则电子邮件地址是否已在使用中。我不想为每个实体管理器查找方法开始并提交一个新事务,因为我认为仅使用一个事务进行多个操作比使用多个操作更有效。我可以在我的方法中用flush()替换commit()吗?
public void createUser(User_ newUser){
UserDao userDao = new UserDao();
Alert alert;
EntityTransaction transaction = entityManager.getTransaction();
try{
transaction.begin();
userDao.find("userName",newUser.getUserName());
transaction.commit();
alert = new Alert(Alert.AlertType.ERROR,"Username already in use", ButtonType.OK);
alert.showAndWait();
if (alert.getResult() == ButtonType.OK)alert.close();
}
catch(NoResultException e){
try{
transaction.begin();
userDao.find("emailAdress",newUser.getEmailAdress());
transaction.commit();
alert = new Alert(Alert.AlertType.ERROR,"E-mail adress already in use", ButtonType.OK);
alert.showAndWait();
if (alert.getResult() == ButtonType.OK) alert.close();
}
catch(NoResultException x){
transaction.begin();
userDao.save(newUser);
transaction.commit();
}
}
catch(RuntimeException e){
transaction.rollback();
}
finally{entityManager.close();}
}
谢谢。
最佳答案
您的代码存在三个问题:
为什么要将查询方法包装在单独的事务中?首先,执行查询不需要查询。其次,您尝试将两个查询方法包装在一个事务中是正确的,但原因是错误的。这与性能关系不大,而与隔离密切相关。这里需要一个事务,只是为了防止在这两个查询之间再次调用 createUser
创建具有相同用户名的用户(显然,出于同样的原因,持久化用户应该是同一事务的一部分) )。
您应该避免使用异常来处理应用程序的正常状态。这不仅是使用异常的正确方法,而且就事务状态而言,您遇到的问题也会少得多。从您期望 userDao.find
抛出 NoResultException
的事实来看,我假设它在内部使用 query.getSingleResult()
。仅当您希望查询始终有结果时才应使用 getSingleResult
。您应该使用 getResultList()
来代替,并结合空性检查,或者更好的是,查询具有给定用户名的 User
实体的 count
您的方法混合了业务逻辑和表示问题。将数据保存到数据库并显示警报绝对不应该通过单一方法完成。如果您绝对需要以与保存数据相同的方法向用户传达错误,请确保在提交事务之后执行此操作,以防止超时。
关于java - 当我想使用find()方法两次时,我可以使用flush()而不是commit()吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44088452/
在MySQL中,执行FLUSH TABLES, PRIVILEGES;和执行FLUSH TABLES;再执行FLUSH PRIVILEGES;效果一样吗?此外,这是否适用于任何刷新选项(FLUSH L
在spring security生成类UserRole或 SecUserSecRole (你可以随便叫它)有一个命令可以创建 new UserRole()并用 .save(flush:flush, i
我正在使用 Hibernate 3.2.6。我正面临异常(exception)情况 save the transient instance before flushing 在我的代码中,有时我们在一个
我有一个 StreamWriter,它的底层流是一个 FileStream。以下代码是否保证 FileStream 也将其缓冲区刷新到文件系统上的实际文件中,还是我需要在 上显式调用 Flush()文
我在 ASP.NET Web API 中使用 PushStreamContent 将事件从服务器推送到客户端(使用服务器发送事件)。每次发送事件后,我都会在 Stream 上调用 Flush 以将缓冲
MSDN说FileStream.Flush(True) “还清除所有中间文件缓冲区。”。 “所有中间文件缓冲区”到底是什么意思? 最佳答案 它会将缓冲在文件系统缓存中的文件数据写入磁盘。该数据通常是根
在我的项目中,我有很多嵌套的对象,几天后服务器在每次查询执行时都变得非常缓慢。 我从object.save(flush:true)中删除了flush:true,这应该避免对象立即被数据库持久化,因为我
假设您需要将二进制数据写入标准输出: sys.stdout.buffer.write(data) 然后要刷新它,您可以使用以下两种方法之一: sys.stdout.flush() sys.stdout
我已经覆盖了 std::ostream::flush() 函数。下面我从示例中删除了所有其他代码: #include #include class CMyStream : public std::
我在我的服务中实现了取消 http 请求,我想测试它: angular.module('EmsWeb.Services').factory('DalService', ['$q', '$http',
有这个 Angular 组件: import { Component, OnDestroy, OnInit } from '@angular/core'; import { asyncSchedule
magento的缓存管理中“Flush Magento Cache”和“Flush Cache Storage”有什么区别? 最佳答案 有时,缓存位置(如 /tmp/)或服务(如 Memcache)会
我有一个实现 postFlush() 的 Hibernate 拦截器.据我了解,刷新后是数据已保存到数据库中,但在调用提交之前可能会回滚。如果我有一个看起来像这样的 hibernate 配置: tru
这是我第一次接触 Clojure,所以我尝试编写一个简单的脚本,它提供基于维基百科的翻译(欢迎任何批评/评论) 问题是:当我从翻译中删除(刷新)时,脚本输出 nil 而不是翻译后的单词。这是为什么?我
我正在开发 iPhone 应用程序并希望使用: CFStreamCreatePairWithSocketToHost(NULL, url, port, &serverReadStream, &serv
我有一个相机将图片发送到回调函数,我想使用 FFmpeg 用这些图片制作一部电影。我遵循了 decoding_encoding 示例 here但我不确定如何使用 got_output 刷新编码器并获取
is_master_def: volatile bool is_master_; is_master_ 值被另一个线程设置为 true,但似乎 is_master_ 值 dosnt 刷新(它没有计算出
什么意思 “我会在您将所有内容发送给客户端并刷新后执行此操作。” 谢谢你 最佳答案 刷新是对数据流进行缓冲时涉及的操作。 让我们假设一个普通的stdout 流。每个字节一到达就打印出来效率很低,这就是
我们正在开发 iMX6Sx Freescale 开发板,使用 Yocto 构建 Linux 内核发行版。我想知道是否有办法检查是否有可能检查文件系统操作(特别是写入)是否真的终止,避免在操作仍在进行时
我已经实现了一个 Java 程序,它通过 ServerSocket 从 GPS 设备读取数据。 ServerSocket serverSocket = new ServerSocket(13811);
我是一名优秀的程序员,十分优秀!