1

我正在创建一个 Web 应用程序,它允许用户使用 spring 和 hibernate 通过 GUI 存储和检索数据库中的信息。

在创建 DAO 和服务层时,我陷入了困境。我想创建一个可以添加新交付的方法。在我的交付表中,我有产品 ID客户 ID,它们都映射到自己的表,分别包含产品名称、产品类型客户名称、客户国家

我遇到的问题是我希望最终用户通过输入产品类型、产品名称、客户名称、客户国家和日期来记录交货。难道我,

(1) 使用添加包含这些对象的新交付的方法创建一个 DAO

或者

(2) 创建一个只将一般对象持久化到数据库的 DAO,然后使用服务方法为每个单独的对象实现 DAO?

感谢您的帮助!

/D

4

1 回答 1

0

这是我的通用 dao 的片段,我将其注入到每个服务层类中。

@Component("Dao")
public class Dao implements IDao  {
    @Resource(name = "sessionFactory")
    private SessionFactory sessionFactory;

    @Override
    public <T> T save(final T o){
        return (T) sessionFactory.getCurrentSession().save(o);
    }

    @Override
    public void delete(final Object object) {
        sessionFactory.getCurrentSession().delete(object);
    }

    @Override
    public <T> T get(final Class<T> type, final Long id) {
        return (T) sessionFactory.getCurrentSession().get(type, id);
    }

    @Override
    public <T> List<T> getFieldsEq(final Class<T> type, final Map<String, Object> restrictions) {
        final Session session = sessionFactory.getCurrentSession();
        final Criteria crit = session.createCriteria(type);
        for (Map.Entry<String, Object> entry : restrictions.entrySet()) {
            crit.add(Restrictions.eq(entry.getKey(), entry.getValue()));
        }

        return crit.list();
    }
}

可以像这样在您的服务层中使用它:

@Transactional(readOnly = true)
public List<City> getCities() {
  return dao.getAll(City.class);
}

当然,您可以为特定的复杂查询扩展 dao。拥有一个通用的 dao 遵循单点责任原则DRY,并使其更易于测试。事务应该在服务层并且直接与工作单元相关。

于 2012-04-16T11:41:57.400 回答