SSh开发,封装dao

手动写一个dao查询类,所有的子类 如UserDao继承这个dao。
核心代码是通过反射获取泛型对象指定的具体类,BaseDao()下的这几行代码,要理解;

public class BaseDao<T, PK extends Serializable> {

    @Inject
    private SessionFactory sessionFactory;
    private Class<?> clazz;

    public static void main(String[] args) {
        new UserDao().getSession();
    }

    public BaseDao() {
        // 通过反射获取泛型的真实的类
        ParameterizedType parameterizedType = (ParameterizedType) this
                .getClass().getGenericSuperclass();
        Type[] types = parameterizedType.getActualTypeArguments();
        clazz = (Class<?>) types[0];
    }

    public Session getSession() {
        return sessionFactory.getCurrentSession();
    }

    public void save(T t) {
        getSession().saveOrUpdate(t);
    }

    @SuppressWarnings("unchecked")
    public T get(PK id) {
        return (T) getSession().get(clazz, id);
    }

    public void del(PK id) {
        getSession().delete(get(id));
    }

    public void del(T t) {
        getSession().delete(t);
    }

    @SuppressWarnings("unchecked")
    public List<T> findAll() {
        return getCriteria().list();
    }

    @SuppressWarnings("unchecked")
    public T findByProperty(String propertyName, Object value) {
        Criteria c = getCriteria();
        c.add(Restrictions.eq(propertyName, value));
        return (T) c.uniqueResult();
    }

    private Criteria getCriteria() {
        return getSession().createCriteria(clazz);
    }

}

UserDao代码如下:
@Named
public class UserDao extends BaseDao<UserInfo, Integer> {
}

这里的@Named 是注解实现,看下一步
这里是UserService,是user服务类,通过注入的方式来使用UserDao

@Named
@Transactional
public class UserService {

    @Inject
    private UserDao userDao;

    public void save(UserInfo user) throws Exception {
        userDao.save(user);
    }

    public UserInfo findByName(String name) {
        return userDao.findByProperty("username", name);
    }

    @Transactional(readOnly = true)
    public List<UserInfo> findAll() {
        return userDao.findAll();
    }

}

你可能感兴趣的:(ssh)