CRUD的共公代码
来源:互联网 发布:python 平方根 编辑:程序博客网 时间:2024/04/27 18:29
package cn.itcast.oa.base;import java.util.List;import cn.itcast.oa.domain.PageBean;import cn.itcast.oa.util.QueryHelper;/** * CRUD的Dao的接口 * * @author * @version V1.0 */public interface DaoSupport<T> {/** * 保存实体 * * @param entity */void save(T entity);/** * 删除实体 * * @param id */void delete(Long id);/** * 更新实体 * * @param entity */void update(T entity);/** * 根据id查询 * * @param id * @return */T getById(Long id);/** * 按id查询 * * @param id * @return */List<T> getByIds(Long[] ids);/** * 查询所有 * * @return */List<T> findAll();/** * 公共的查询分页信息的方法 * * @param pageNum * 当前页(默认:第1页) * @param pageSize * 每页显示多少条(默认:每页显示10条) * @param hql * 查询数据列表的HQL * @param paramenters * 参数列表,与HQL中占位符参数一一对应 * @return 分页信息 */@DeprecatedPageBean getPageBean(int pageNum, int pageSize, String hql, List<Object> parameters);/** * 公共的查询分页信息的方法(最终版) * * @param pageNum * 当前页(默认:第1页) * @param pageSize * 每页显示多少条(默认:每页显示10条) * @param queryHelper * 查询HQL与参数列表 * @return 分页信息 */PageBean getPageBean(int pageNum, int pageSize, QueryHelper queryHelper);}
package cn.itcast.oa.base;import java.lang.reflect.ParameterizedType;import java.util.Collections;import java.util.List;import javax.annotation.Resource;import org.hibernate.Query;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.springframework.transaction.annotation.Transactional;import cn.itcast.oa.domain.PageBean;import cn.itcast.oa.util.QueryHelper;/** * CRUD的Dao的实现类 * * @author * @version V1.0 */// @Transactional("txManager")注解可以被继承// @Transactional("txManager")注解对父类中声明的方法无效@Transactional("txManager")@SuppressWarnings({ "unchecked", "rawtypes" })public class DaoSupportImpl<T> implements DaoSupport<T> {@Resourceprivate SessionFactory sessionFactory;private Class<T> clazz;// 这是一个问题public DaoSupportImpl() {// 使用反射技术得到T的真实类型ParameterizedType pt = (ParameterizedType) this.getClass().getGenericSuperclass();// 获取当前new的对象的泛型的父类类型this.clazz = (Class<T>) pt.getActualTypeArguments()[0];// 获取第一个类型参数的真实类型System.out.println("clazz ---> " + clazz);}/** * 获取当前可用的Session * * @return */protected Session getSession() {return sessionFactory.getCurrentSession();}@Transactionalpublic void save(T entity) {getSession().save(entity);}public void delete(Long id) {Object obj = getById(id);if (obj != null) {getSession().delete(obj);}}public void update(T entity) {getSession().update(entity);}public T getById(Long id) {if (id == null) {return null;} else {return (T) getSession().get(clazz, id);}}public List<T> getByIds(Long[] ids) {if (ids == null || ids.length == 0) {return Collections.EMPTY_LIST;} else {return getSession().createQuery(//"from " + clazz.getSimpleName() + " where id in (:ids)")//.setParameterList("ids", ids)//.list();}}public List<T> findAll() {return getSession().createQuery(//"from " + clazz.getSimpleName())//.list();}// 公共的查询分页信息的方法@Deprecatedpublic PageBean getPageBean(int pageNum, int pageSize, String hql, List<Object> parameters) {System.out.println("------> DaoSupporImpl.getPageBean()");// 查询本页的数据列表Query listQuery = getSession().createQuery(hql);// 创建查询对象if (parameters != null) {// 设置参数for (int i = 0; i < parameters.size(); i++) {listQuery.setParameter(i, parameters.get(i));}}listQuery.setFirstResult((pageNum - 1) * pageSize);//listQuery.setMaxResults(pageSize);//List list = listQuery.list();// 执行查询// 查询总记录数量Query countQuery = getSession().createQuery("select count(*) " + hql);if (parameters != null) {// 设置参数for (int i = 0; i < parameters.size(); i++) {countQuery.setParameter(i, parameters.get(i));}}Long count = (Long) countQuery.uniqueResult();// 执行查询return new PageBean(pageNum, pageSize, count.intValue(), list);}// 公共的查询分页信息的方法(最终版)public PageBean getPageBean(int pageNum, int pageSize, QueryHelper queryHelper) {System.out.println("------> DaoSupporImpl.getPageBean(int pageNum, int pageSize, QueryHelper queryHelper)");List<Object> parameters = queryHelper.getParameters();// 查询本页的数据列表Query listQuery = getSession().createQuery(queryHelper.getListQueryHql());// 创建查询对象if (parameters != null) {// 设置参数for (int i = 0; i < parameters.size(); i++) {listQuery.setParameter(i, parameters.get(i));}}listQuery.setFirstResult((pageNum - 1) * pageSize);//listQuery.setMaxResults(pageSize);//List list = listQuery.list();// 执行查询// 查询总记录数量Query countQuery = getSession().createQuery(queryHelper.getCountQueryHql());if (parameters != null) {// 设置参数for (int i = 0; i < parameters.size(); i++) {countQuery.setParameter(i, parameters.get(i));}}Long count = (Long) countQuery.uniqueResult();// 执行查询return new PageBean(pageNum, pageSize, count.intValue(), list);}}
Action公共代码
package cn.itcast.oa.base;import java.lang.reflect.ParameterizedType;import javax.annotation.Resource;import cn.itcast.oa.domain.User;import cn.itcast.oa.service.DepartmentService;import cn.itcast.oa.service.ForumService;import cn.itcast.oa.service.PrivilegeService;import cn.itcast.oa.service.ReplyService;import cn.itcast.oa.service.RoleService;import cn.itcast.oa.service.TopicService;import cn.itcast.oa.service.UserService;import com.opensymphony.xwork2.ActionContext;import com.opensymphony.xwork2.ActionSupport;import com.opensymphony.xwork2.ModelDriven;/** * 公共实例声明Action类 * * @author 风清杨 * @version V1.0 */@SuppressWarnings("serial")public abstract class BaseAction<T> extends ActionSupport implements ModelDriven<T> {/** * 获了当前登录的用户 * * @return */protected User getCurrentUser() {return (User) ActionContext.getContext().getSession().get("user");}// ===========Service实例的声明===========@Resourceprotected DepartmentService departmentService;@Resourceprotected RoleService roleService;@Resourceprotected UserService userService;@Resourceprotected PrivilegeService privilegeService;@Resourceprotected ForumService forumService;@Resourceprotected TopicService topicService;@Resourceprotected ReplyService replyService;// ===========ModelDriven的支持===========protected T model;@SuppressWarnings("unchecked")public BaseAction() {// 通过反射获取model的真实类型ParameterizedType pt = (ParameterizedType) this.getClass().getGenericSuperclass();Class<T> clazz = (Class<T>) pt.getActualTypeArguments()[0];// 通过返射创建model的实例try {model = clazz.newInstance();} catch (Exception e) {throw new RuntimeException();}}public T getModel() {return model;}// ========= 分页用的参数 =========/** 当前页(默认:第1页) */protected int pageNum = 1;;/** 每页显示多少条(默认:每页显示10条) */protected int pageSize = 10;// ---public int getPageNum() {return pageNum;}public void setPageNum(int pageNum) {this.pageNum = pageNum;}public int getPageSize() {return pageSize;}public void setPageSize(int pageSize) {this.pageSize = pageSize;}}
阅读全文
0 0
- CRUD的共公代码
- ibatis的CRUD代码
- jdbc crud的演示代码
- 分享java操作mongodb的crud代码
- MyBatis 的CRUD 功能代码演示
- java代码对MongoDB的CRUD
- springMVC CRUD模板代码
- 共享用js来设置cookie的代码
- C#的NHibernate的CRUD开发入门代码例子
- 【代码生成】针对单表生成CRUD的存储过程
- ibatis的CRUD代码 -------懂这些,ibatis差不多就会用了。
- 解决Hibernate 实体类之间CRUD的代码冗余
- 三极管电路共集、共基、共射的区别
- SSM框架CRUD代码生成器
- 自动生成数据对象代码和CRUD操作的C#代码生成器
- CRUD的含义
- CRUD的含义
- CRUD的相关问题
- VJ组队赛->Dancing Stars on Me(5533)
- 简述PRIMARY KEY与identity(1,1)的含义
- url地址获取判断
- 韩子笑讲课资料三:各类文开篇和大纲的写法。
- 关于探探图片滑动操作
- CRUD的共公代码
- C 语言返璞归真: 指针篇(1)
- 在linux上搭建javaweb服务器
- 【N32926】简单测试ARM Linux嵌入式系Nand存储读写速度
- 动态网页
- [Shell]特殊变量$0$#$*$@$?和命令行参数
- 2016中国国际石墨烯创新大会展商名录抢先看
- Android-运行时权限
- redis中文乱码问题