- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我找不到使用 DAO 设置关联的解决方案。需要解释一下。有 3 个实体:银行、客户和账户。银行和客户是双向多对多关联,客户和账户是一对多关联。每个实体的 DAO 都有一个 GenericDAO 接口(interface)来实现。由于应用程序不是多线程,我决定通过在 DAO 接口(interface)实现的每种方法中打开和关闭 session 来实现每个请求 session “模式”。请看一下代码。问题描述如下代码。
POJO 银行
@Entity
@Table(name = "bank")
public class Bank {
private int bankID;
private String bankName;
private Set<Client> setOfClients;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "bank_id")
public int getBankID() {
return bankID;
}
public void setBankID(int bankID) {
this.bankID = bankID;
}
@Column(name = "bank_name")
public String getBankName() {
return bankName;
}
public void setBankName(String bankName) {
this.bankName = bankName;
}
@ManyToMany(mappedBy = "setOfBanks", fetch = FetchType.EAGER)
public Set<Client> getSetOfClients() {
return setOfClients;
}
public void setSetOfClients(Set<Client> setOfClients) {
this.setOfClients = setOfClients;
}
}**
客户端 POJO
@Entity
@Table(name = "client")
public class Client {
private int clientID;
private String firstName;
private String secondName;
private Set<Account> setOfAccounts;
private Set<Bank> setOfBanks;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "client_id")
public int getClientID() {
return clientID;
}
public void setClientID(int clientID) {
this.clientID = clientID;
}
@Column(name = "first_name")
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
@Column(name = "second_name")
public String getSecondName() {
return secondName;
}
public void setSecondName(String secondName) {
this.secondName = secondName;
}
@OneToMany(mappedBy = "clientID", cascade = {CascadeType.ALL})
public Set<Account> getSetOfAccounts() {
return setOfAccounts;
}
public void setSetOfAccounts(Set<Account> setOfAccounts) {
this.setOfAccounts = setOfAccounts;
}
@ManyToMany(targetEntity = Bank.class, cascade = {CascadeType.ALL}, fetch = FetchType.EAGER)
@JoinTable(
name = "bank_client",
joinColumns = {@JoinColumn(name = "client_id", nullable = false, referencedColumnName = "client_id")},
inverseJoinColumns = {@JoinColumn(name = "bank_id", nullable = false, referencedColumnName = "bank_id")}
)
public Set<Bank> getSetOfBanks() {
return setOfBanks;
}
public void setSetOfBanks(Set<Bank> setOfBanks) {
this.setOfBanks = setOfBanks;
}
}
ClientDAO
public class ClientDAO<Client> implements GenericDAO<Client>{
private Session session;
@Override
public void saveEntity(Client entity) {
try {
session = SessionFactoryUtil.getSessionFactory().openSession();
session.getTransaction().begin();
session.save(entity);
session.getTransaction().commit();
} catch (HibernateException e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
}
@Override
public void deleteEntity(Client entity) {
try {
session = SessionFactoryUtil.getSessionFactory().openSession();
session.getTransaction().begin();
session.delete(entity);
session.getTransaction().commit();
} catch (HibernateException e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
}
@Override
public void updateEntity(Object entity) {
try {
session = SessionFactoryUtil.getSessionFactory().openSession();
session.getTransaction().begin();
session.update(entity);
session.getTransaction().commit();
} catch (HibernateException e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
}
@Override
public Client getEntityByID(int id) {
Client client = null;
try {
session = SessionFactoryUtil.getSessionFactory().openSession();
session.getTransaction().begin();
client = (Client) session.get(model.entity.Client.class, id);
} catch (HibernateException e) {
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
return client;
}
@Override
public List<Client> getAllEntities() {
List<Client> result = null;
try {
session = SessionFactoryUtil.getSessionFactory().openSession();
session.getTransaction().begin();
result = session.createQuery("from Client").list();
session.getTransaction().commit();
} catch (HibernateException e) {
if (session != null) {
session.getTransaction().rollback();
}
e.printStackTrace();
} finally {
session.close();
}
return result;
}
}
BankDAO 有类似的方法实现,但与银行实体规范相关
主要方法
public class Main {
public static void main(final String[] args) {
ClientDAO<Client> clientDAO = new ClientDAO<Client>();
BankDAO<Bank> bankDAO = new BankDAO<Bank>();
Client client = clientDAO.getEntityByID(11);
Bank bank = bankDAO.getEntityByID(3);
Set<Bank> setOfBanks = client.getSetOfBanks();
setOfBanks.add(bank);
Set<Client> setOfClients = bank.getSetOfClients();
setOfClients.add(client);
}
}
我没有提到有一个中间表,其中包含客户表和银行表的外键值(它需要反射(reflect)它们的多对多关联)。主方法调用的结果应该是中间表中新添加的值(客户表和银行表的外键)。证明该协会已成立。但是当我调用 main-method 时什么也没有发生。据我了解,当我 setOfBanks.add(bank)
和 setOfClients.add(client)
时,对象会添加到与持久对象不相关的集合中,因为 session 已关闭。我不知道如何正确打开和关闭 session 以便在 session 内建立关联。希望我能清楚地描述这个问题。我真的很感激任何回复。
最佳答案
您所实现的看起来更像 session-per-operation anti-pattern比海事组织的每个请求 session 模式。 “每个请求 session ”通常是指客户端-服务器或 Web 应用程序中的一个请求,其中一个请求通常涉及多个数据库操作。
将该模式应用于像您这样的命令行应用程序比较困难,但在您的情况下,最接近请求的可能是从命令行运行应用程序。因此,我同意 nachokk 的观点,您应该在 main 方法的开头打开 session ,并在最后关闭它。
关于java - Hibernate:如何处理DAO中的Session以正确设置关联?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25751993/
我有组件需要更新客户和客户地址的数据库(通过 JDBC)。从 CustomerDAO 调用 CustomerAddressDAO 是否合适?或者创建一个单独的“CustomerDataManager”
任何人都可以解释MS Access 2007中DAO.Recordset,DAO.Recordsets和DAO.Recordset2之间的区别吗?基本上使用记录集。...举一个例子,使它更清晰。我从“
所以我正在编写一个个人项目来学习 Web 编程,并且我遇到了 DAO 模式。我构建了一些类(模型),并且像几乎所有程序一样,它们是嵌套的(例如:类 Payment 具有对 Author 实例的引用)。
我有一个基本问题。 我一直在创建关注点分离的 DAO。每个 DAO 都专注于上下文中的 BusinessObject。我的问题是如何在另一个 DAO 中使用一个 DAO 方法。我认为这是错误的,但没有
有没有办法使用 Android Room Persistence Library 将 DAO 作为依赖项添加到其他 DAO 中,也许是使用 Dagger2?我试图避免在使用事务对多个表执行操作的 DA
通常,我会尝试以一种完全依赖于自身的方式来构建我的 DAO 类。它们可以与多个表交互,但前提是数据与基础对象相关。例如,假设我有一个约会对象,约会 DAO 从约会表中提取数据。如果约会表是一个服务 i
在学校学习过 Java 后,我对 DAO 模式( Data access object )非常熟悉。然而在工作中我使用.NET。在 .NET 中,经常讨论 DAL( Data Access Layer
我一直在尝试按照以下步骤创建一个通用的 DAO: http://www.ibm.com/developerworks/java/library/j-genericdao/index.html 不过,我
Java EE 中的最佳实践是什么? 在服务(或管理器)类中创建 DAO 类的实例 SalesDAO salesDao = new SalesDAOImpl(); salesDao.findCusto
这有道理吗? 假设我需要从 DB 中获取一个对象,该对象与另一个对象有关系(由 DB 中的外键表示,并由我的域对象中的组合表示)。如果在我的第一个 DAO 中,我为对象 1 获取数据,然后为对象 2
我目前正在为应用程序创建数据访问层。此应用程序最初将连接到 Oracle 数据库,但稍后也会连接到 DB2 数据库。 为了连接到数据库,我将使用 JDBC。在这个时候我正在考虑我的选择。在我看来,我有
我正在 JSF 中设计一些数据“块” 我从每个块的 Java bean 中获取我的数据。 我的问题是我的块从多个表中获取数据。 例如: 描述 的块客户的个人资料 由组成: 客户名称(在表 客户 中)
将 DAO 类与应用程序代码中实际实例化的 DAO 类分开有什么好处,即为什么不在这样的场景中直接实例化 DAO 类: Class CreateIocContainer{ p s v main
我正在为我的 DataNucleus JDO DAO 创建通用 DAO。通用 DAO 将执行获取、更新、删除、创建操作和一些其他通用操作,因此这些实现可以在更具体的 DAO 中进行扩展。 是否有可能以
这可能是一件非常微不足道的事情,但我是一些面向对象模式的新手。 简而言之,在另一个 DAO 中使用一个 DAO 中的方法是一种不好的做法吗?我试图在 DAO 中创建一个实体,但发现仅使用该 DAO 很
我参与了一个 Java 项目,该项目从不同的支付代理获取支付信息,对其进行处理并将其存储到我们的计费系统(数据库)中。 由于我们有不同的代理,因此支付协议(protocol)也不同,因此我们有时有相似
考虑以下 Room DAO @Dao public abstract class JobDao { @Insert public abstract long insert( Job v
我有一个“容器”类,其字段包含在多个数据库表中,我使用 DAO 模式来访问数据。 问题是,我应该为这个“容器”类创建一个 DAO,还是每个表有一个 DAO 并合并它们的数据更好? 最佳答案 您应该根据
我们正在通过 @Service 和 @Component 注释使用 Spring @Autowired 改造一个新的面向服务的架构。 我一直在和我的同事争论不让每个 DAO 都有接口(interfac
我有通用的 DAO: @NoRepositoryBean interface ICrudDao extends Repository { void delete(T deleted);
我是一名优秀的程序员,十分优秀!