Java分层中遇到的问题
陆陆续续写了一些Java的项目,用了Spring系列和Hibernate这样的框架。在设计Service层和Dao层的时候碰到了一些想不清楚的问题。
以一个简单的用户信息管理功能为例,如果不用Spring Data之类的东西。那么我一般会这么写代码
controller往上没什么好说的,controller调用service就好了,service调用dao。
关键在于service这里。我可能会这么写
...
@Autowired
UserDao userDao;
public void saveUser(String userName){
userDao.save(userName);
}
public User findUser(String userName){
return userDao.findUser(userName);
}
...
然后在整个service的实现类上面注解@Transaction
Dao实现的代码就是
...
@Autowired
SessionFactory sessionFactory;
public void save(String userName){
Session session=sessionFactory.getCurrentSession();
session.save(userName);
}
...
问题就来了,如果按照这样的写法,那么首先Hibernate的一级缓存似乎就没有起到作用了。
因为在Dao中,每一个方法都获取一个Session来进行操作,方法间并不共享Session。也就是说如果Service的一个方法中调用了Dao的两个方法,这两个方法的Session不一样,一级缓存根本没用。
其次就是Service层中查找出来的对象是游离态的。
在Service的方法中如果find了一个对象然后调用这个的对象的Set方法,数据库中是不会更新的。因为调用Dao的find方法后Session关闭,对象从持久态变成了游离态,所以这时候要更新对象的信息只能手动再写一句update(User u)
,就是这样:
public void update(String userName,String password){
User u=userDao.findUser(userName);
u.setPassword(password);
userDao.update(u);
}
这显然是不好的一种方式。
但是如果想改掉前面两个缺点,就必须把Session提到Service层,让Service的一个方法用一个Session,这样上面提到的两个问题就都能解决。可是Session本应该是Dao层的东西,提升到Service层似乎也是不好的做法。
不知道这里头的矛盾到底怎么解决?
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。