jdk1.5的推出为我们带来了枚举、泛型、foreach循环、同步工具包等等好东西。其中,泛型的使用为我们的代码开发提供了很大的简便,简化了我们的代码。
1、设计思路
1)GenericDao泛型类提供所有的增删改查功能;
2)所有的dao在继承GenericDao泛型类拥有自身的增删改查功能,不需再写其他代码。
2、实现GenericDao
- public abstract class GenericDao<T, PK extends Serializable> {
- protected final Logger logger = LoggerFactory.getLogger(getClass());
- public static final String POSTFIX_SELECTBYID = ".selectById";
- public static final String POSTFIX_SELECTBYIDS = ".selectByIds";
- public static final String POSTFIX_SELECTBYMAP = ".selectByMap";
- public static final String POSTFIX_SELECTIDSLIKEBYMAP = ".selectIdsLikeByMap";
- public static final String POSTFIX_PKSELECTMAP = ".pkSelectByMap";
- public static final String POSTFIX_COUNT = ".count";
- public static final String POSTFIX_COUNTLIKEBYMAP = ".countLikeByMap";
- public static final String POSTFIX_INSERT = ".insert";
- public static final String POSTFIX_DELETEBYID = ".deleteById";
- public static final String POSTFIX_DELETEBYIDS = ".deleteByIds";
- public static final String POSTFIX_DELETEBYIDSMAP = ".deleteByIdsMap";
- public static final String POSTFIX_DELETEBYMAP = ".deleteByMap";
- public static final String POSTFIX_UPDATE = ".update";
- public static final String POSTFIX_UPDATEBYMAP = ".updateByMap";
- public static final String POSTFIX_UPDATEBYIDSMAP = ".updateByIdsMap";
- protected Class<T> clazz;
- protected String clazzName;
- protected T t;
- // 定义主从数据库服务器,主数据库负责(Write op),从数据库负责(read op)
- @Autowired
- protected SqlMapClientTemplate masterSqlMapClientTemplate;
- @Autowired
- protected SqlMapClientTemplate slaveSqlMapClientTemplate;
- public GenericDao() {
- // 通过范型反射,取得在子类中定义的class.
- clazz = (Class<T>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
- clazzName = clazz.getSimpleName();
- }
- public Integer count(String propertyName, Object propertyValue) {
- return count(new String[]{propertyName},new Object[]{propertyValue});
- }
- public Integer count(String[] propertyNames, Object[] propertyValues) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < propertyNames.length; i++) {
- map.put(propertyNames[i], propertyValues[i]);
- }
- return (Integer) slaveSqlMapClientTemplate.queryForObject(clazz.getName() + POSTFIX_COUNT, map);
- }
- @Override
- public Integer countLikeByMap(String[] propertyNames, Object[] propertyValues) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < propertyNames.length; i++) {
- map.put(propertyNames[i], propertyValues[i]);
- }
- return (Integer) slaveSqlMapClientTemplate.queryForObject(clazz.getName() + POSTFIX_COUNTLIKEBYMAP, map);
- }
- /** 根据自定义SqlMap中的条件语句查询出记录数量 */
- public Integer countByStatementPostfix(String statementPostfix,String[] properties, Object[] propertyValues){
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- return (Integer) slaveSqlMapClientTemplate.queryForObject(clazz.getName() + statementPostfix, map);
- }
- /**
- * 通过id得到实体对象
- */
- public T findById(PK id) {
- return (T) slaveSqlMapClientTemplate.queryForObject(clazz.getName() + POSTFIX_SELECTBYID, id);
- }
- /**
- * 根据ids获取实体列表
- *
- * @param ids
- * @return
- */
- public List<T> findByIds(List<PK> ids) {
- return (List<T>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_SELECTBYIDS, ids);
- }
- /**
- * 直接从数据库查询出ids列表(包括符合条件的所有id)
- *
- * @param properties
- * 查询条件字段名
- * @param propertyValues
- * 字段取值
- * @return
- */
- public List<PK> findIdsBy(String[] properties, Object[] propertyValues, String orderBy, String order) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- return (List<PK>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_PKSELECTMAP, map);
- }
- /**
- * 根据条件查询结果
- *
- * @param properties
- * 查询条件名
- * @param propertyValues
- * 查询条件值
- * @return
- */
- public List<T> findByMap(String[] properties, Object[] propertyValues, String orderBy, String order) {
- return (List<T>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_SELECTBYMAP, map);
- }
- /**
- * 根据条件查询结果的id列表
- *
- * @param properties
- * 查询条件名
- * @param propertyValues
- * 查询条件值
- * @return
- */
- public List<PK> findIdsByMap(String[] properties, Object[] propertyValues, String orderBy, String order) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- return (List<PK>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_PKSELECTMAP, map);
- }
- /**
- * 分页查询(未处理缓存)
- *
- * @param properties
- * 查询条件字段名
- * @param propertyValues
- * 字段取值
- * @return
- */
- public List<T> pageQueryBy(String[] properties, Object[] propertyValues, String orderBy, String order, int pageSize, int pageNo) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- map.put("limit", true);
- map.put("start", (pageNo - 1) * pageSize );// limit 操作
- map.put("end", pageSize);
- return (List<T>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_SELECTBYMAP, map);
- }
- /**
- * 从数据库分页查询出ids列表的前200个id
- *
- * @param properties
- * 查询条件字段名
- * @param propertyValues
- * 字段取值
- * @return
- */
- protected List<PK> pageQueryIdsBy(String[] properties, Object[] propertyValues, String orderBy, String order) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- map.put("limit", true);
- map.put("start", 0);// 操作
- map.put("end", Config.getInstance().getPageCacheSize());
- return (List<PK>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_PKSELECTMAP, map);
- }
- /**
- * 分页查询出id列表(处理缓存)
- *
- * @param properties
- * 查询条件字段名
- * @param propertyValues
- * 字段取值
- * @return
- */
- public List<PK> pageQueryIdsByMap(String[] properties, Object[] propertyValues, String orderBy, String order, int pageSize, int pageNo) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- map.put("limit", true);
- map.put("start", (pageNo - 1) * pageSize );// limit 操作
- map.put("end", pageSize);
- return (List<PK>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_PKSELECTMAP, map);
- }
- /** like分页查询(不走列表缓存) */
- public List<T> pageLikeBy(String[] properties, Object[] propertyValues, String orderBy, String order, int pageSize, int pageNo){
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- map.put("limit", true);
- map.put("start", (pageNo - 1) * pageSize );// limit 操作
- map.put("end", pageSize);
- List<PK> ids = (List<PK>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + POSTFIX_SELECTIDSLIKEBYMAP, map);
- return findByIds(ids);
- }
- /**
- * 新增对象
- */
- public Serializable insert(T o) throws Exception {
- if (t instanceof QueryCachable) {
- // 清除受影响的缓存
- clearListCache(o);
- }
- return (Serializable) masterSqlMapClientTemplate.insert(clazz.getName() + POSTFIX_INSERT, o);
- }
- /**
- * 更新对象
- */
- public T update(T o) throws Exception {
- masterSqlMapClientTemplate.update(clazz.getName() + POSTFIX_UPDATE, o);
- return o;
- }
- /**
- * 更新对象的部分属性
- */
- public int update(PK id, String[] properties, Object[] propertyValues) throws Exception {
- // 更新数据库
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- map.put("id", id);
- return masterSqlMapClientTemplate.update(clazz.getName() + POSTFIX_UPDATEBYMAP, map);
- }
- /**
- * 根据ID列表更新对象的部分属性
- */
- public int updateByIdsMap(List<PK> ids,String[] properties, Object[] propertyValues) throws Exception{
- // 更新数据库
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- map.put("ids", ids);
- return masterSqlMapClientTemplate.update(clazz.getName() + POSTFIX_UPDATEBYIDSMAP, map);
- }
- /**
- * 根据ID删除对象
- */
- public void deleteById(PK id) throws Exception {
- masterSqlMapClientTemplate.delete(clazz.getName() + POSTFIX_DELETEBYID, id);
- }
- /**
- * 根据ID删除对象
- */
- public void deleteByIds(List<PK> ids) throws Exception {
- masterSqlMapClientTemplate.delete(clazz.getName() + POSTFIX_DELETEBYIDS, ids);
- }
- /** 根据ID及条件删除对象 */
- public void deleteByIdsMap(List<PK> ids, String[] properties, Object[] propertyValues) throws Exception {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- map.put("ids", ids);
- masterSqlMapClientTemplate.delete(clazz.getName() + POSTFIX_DELETEBYIDSMAP, map);
- }
- /**
- * 根据条件删除对象
- */
- public int deleteByMap(String[] properties, Object[] propertyValues) throws Exception {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- return masterSqlMapClientTemplate.delete(clazz.getName() + POSTFIX_DELETEBYMAP, map);
- }
- /**
- * 根据自定义SqlMap中的条件语句查询出列表(注意:不处理缓存)
- */
- public List<T> findByStatementPostfix(String statementPostfix, String[] properties, Object[] propertyValues, String orderBy, String order) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- return slaveSqlMapClientTemplate.queryForList(clazz.getName() + statementPostfix, map);
- }
- /**
- * 根据自定义SqlMap中的条件语句查询出列表(注意:不处理缓存)
- */
- public List<T> pageQueryByStatementPostfix(String statementPostfix, String[] properties, Object[] propertyValues, String orderBy, String order,int pageSize,int pageNo) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- if (orderBy != null) {
- map.put("orderBy", orderBy);
- map.put("order", order);
- }
- map.put("limit", true);
- map.put("start", (pageNo - 1) * pageSize );// limit 操作
- map.put("end", pageSize);
- List<PK> ids = (List<PK>) slaveSqlMapClientTemplate.queryForList(clazz.getName() + statementPostfix, map);
- return findByIds(ids);
- }
- /**
- * 根据自定义SqlMap中的条件语句更新数据(注意:不处理缓存)
- */
- public void updateByStatementPostfix(String statementPostfix, String[] properties, Object[] propertyValues) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- masterSqlMapClientTemplate.update(clazz.getName() + statementPostfix, map);
- }
- /**
- * 根据自定义SqlMap中的条件语句删除数据(注意:不处理缓存)
- */
- public void deleteByStatementPostfix(String statementPostfix, String[] properties, Object[] propertyValues) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- masterSqlMapClientTemplate.delete(clazz.getName() + statementPostfix, map);
- }
- /**
- * 根据自定义SqlMap中的条件语句插入数据(注意:不处理缓存)
- */
- public void insertByStatementPostfix(String statementPostfix, String[] properties, Object[] propertyValues) {
- Map<String, Object> map = new HashMap<String, Object>();
- for (int i = 0; i < properties.length; i++) {
- map.put(properties[i], propertyValues[i]);
- }
- masterSqlMapClientTemplate.insert(clazz.getName() + statementPostfix, map);
- }
- }
3、所有其他Dao只需继承GenericDao,不需再写增删改查的方法
- package com.teacherclub.business.album.dao;
- import org.springframework.stereotype.Repository;
- import com.teacherclub.business.album.entity.Album;
- import com.teacherclub.core.mem.MemcacheUtil;
- import com.teacherclub.core.orm.EntityCachable;
- import com.teacherclub.core.orm.dao.impl.GenericDao;
- @Repository
- public class AlbumDao extends GenericDao<Album,Integer> {
- }
此泛型的实现,关键在于:clazz = (Class<T>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
相关推荐
漫画作品与时间旅行题材
Spring Boot特点: 1、创建一个单独的Spring应用程序; 2、嵌入式Tomcat,无需部署WAR文件; 3、简化Maven配置; 4、自动配置Spring; 5、提供生产就绪功能,如指标,健康检查和外部配置; 6、绝对没有代码生成和XML的配置要求;第一章 绪 论 1 1.1背景及意义 1 1.2国内外研究概况 2 1.3 研究的内容 2 第二章 关键技术的研究 3 2.1 相关技术 3 2.2 Java技术 3 2.3 ECLIPSE 开发环境 4 2.4 Tomcat介绍 4 2.5 Spring Boot框架 5 第三章 系统分析 5 3.1 系统设计目标 6 3.2 系统可行性分析 6 3.3 系统功能分析和描述 7 3.4系统UML用例分析 8 3.4.1管理员用例 9 3.4.2用户用例 9 3.5系统流程分析 10 3.5.1添加信息流程 11 3.5.2操作流程 12 3.5.3删除信息流程 13 第四章 系统设计 14 4.1 系统体系结构 15 4.2 数据库设计原则 16 4.3 数据表 17 第五章 系统实现 18 5.1用户功能模块 18 5.2
内容概要:本文作为PyTorch的入门指南,首先介绍了PyTorch相较于TensorFlow的优势——动态计算图、自动微分和丰富API。接着讲解了环境搭建、PyTorch核心组件如张量(Tensor)、autograd模块以及神经网络的定义方式(如nn.Module),并且给出了详细的神经网络训练流程,包括前向传播、计算损失值、进行反向传播以计算梯度,最终调整权重参数。此外还简要提及了一些拓展资源以便进一步探索这个深度学习工具。 适用人群:初次接触深度学习技术的新学者和技术爱好者,有一定程序基础并希望通过PyTorch深入理解机器学习算法实现的人。 使用场景及目标:该文档有助于建立使用者对于深度学习及其具体实践有更加直观的理解,在完成本教程之后,读者应当能够在个人设备上正确部署Python环境,并依据指示独立创建自己的简易深度学习项目。 其他说明:文中所提及的所有示例均可被完整重现,同时官方提供的资料链接也可以方便有兴趣的人士对感兴趣之处继续挖掘,这不仅加深了对PyTorch本身的熟悉程度,也为未来的研究或者工程项目打下了良好的理论基础和实践经验。
古镇美食自驾游:舌尖上的历史韵味
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
漫画作品与神话传说融合
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
ADC推理软件AI程序
漫画作品与科幻元素融合
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
java-springboot+vue景区民宿预约系统实现源码(完整前后端+mysql+说明文档+LunW+PPT).zip
在智慧城市建设的大潮中,智慧园区作为其中的璀璨明珠,正以其独特的魅力引领着产业园区的新一轮变革。想象一下,一个集绿色、高端、智能、创新于一体的未来园区,它不仅融合了科技研发、商业居住、办公文创等多种功能,更通过深度应用信息技术,实现了从传统到智慧的华丽转身。 智慧园区通过“四化”建设——即园区运营精细化、园区体验智能化、园区服务专业化和园区设施信息化,彻底颠覆了传统园区的管理模式。在这里,基础设施的数据收集与分析让管理变得更加主动和高效,从温湿度监控到烟雾报警,从消防水箱液位监测到消防栓防盗水装置,每一处细节都彰显着智能的力量。而远程抄表、空调和变配电的智能化管控,更是在节能降耗的同时,极大地提升了园区的运维效率。更令人兴奋的是,通过智慧监控、人流统计和自动访客系统等高科技手段,园区的安全防范能力得到了质的飞跃,让每一位入驻企业和个人都能享受到“拎包入住”般的便捷与安心。 更令人瞩目的是,智慧园区还构建了集信息服务、企业服务、物业服务于一体的综合服务体系。无论是通过园区门户进行信息查询、投诉反馈,还是享受便捷的电商服务、法律咨询和融资支持,亦或是利用云ERP和云OA系统提升企业的管理水平和运营效率,智慧园区都以其全面、专业、高效的服务,为企业的发展插上了腾飞的翅膀。而这一切的背后,是大数据、云计算、人工智能等前沿技术的深度融合与应用,它们如同智慧的大脑,让园区的管理和服务变得更加聪明、更加贴心。走进智慧园区,就像踏入了一个充满无限可能的未来世界,这里不仅有科技的魅力,更有生活的温度,让人不禁对未来充满了无限的憧憬与期待。
边境自驾游异国风情深度体验
在智慧城市建设的大潮中,智慧园区作为其中的璀璨明珠,正以其独特的魅力引领着产业园区的新一轮变革。想象一下,一个集绿色、高端、智能、创新于一体的未来园区,它不仅融合了科技研发、商业居住、办公文创等多种功能,更通过深度应用信息技术,实现了从传统到智慧的华丽转身。 智慧园区通过“四化”建设——即园区运营精细化、园区体验智能化、园区服务专业化和园区设施信息化,彻底颠覆了传统园区的管理模式。在这里,基础设施的数据收集与分析让管理变得更加主动和高效,从温湿度监控到烟雾报警,从消防水箱液位监测到消防栓防盗水装置,每一处细节都彰显着智能的力量。而远程抄表、空调和变配电的智能化管控,更是在节能降耗的同时,极大地提升了园区的运维效率。更令人兴奋的是,通过智慧监控、人流统计和自动访客系统等高科技手段,园区的安全防范能力得到了质的飞跃,让每一位入驻企业和个人都能享受到“拎包入住”般的便捷与安心。 更令人瞩目的是,智慧园区还构建了集信息服务、企业服务、物业服务于一体的综合服务体系。无论是通过园区门户进行信息查询、投诉反馈,还是享受便捷的电商服务、法律咨询和融资支持,亦或是利用云ERP和云OA系统提升企业的管理水平和运营效率,智慧园区都以其全面、专业、高效的服务,为企业的发展插上了腾飞的翅膀。而这一切的背后,是大数据、云计算、人工智能等前沿技术的深度融合与应用,它们如同智慧的大脑,让园区的管理和服务变得更加聪明、更加贴心。走进智慧园区,就像踏入了一个充满无限可能的未来世界,这里不仅有科技的魅力,更有生活的温度,让人不禁对未来充满了无限的憧憬与期待。
,,CAD、DXF导图,自动进行位置路径规划,源码可进行简单功能添加实现设备所需功能,已经在冲孔机,点胶机上应用,性价比超高。 打孔机实测一分钟1400个孔 ,CAD、DXF导图;自动位置路径规划;源码功能添加;设备功能实现;冲孔机点胶机应用;高性价比。,CAD导图DXF,自动规划位置路径,实测打孔速度惊人!性价比超高冲孔机实现多功能定制
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
本地部署,LM Studio,可以让大家本地部署在自己家里的电脑deepseek,再也不用忍受网站上deepseek的服务器繁忙的烦恼