JPA的一些坑
一些 jpa
2023-09-27 14:24:47 时间
推荐一篇比较好的介绍JPA的文章:使用 Spring Data JPA 简化 JPA 开发
JPA坑1:不支持Limit查询
JPA是不支持Limit分页查询,而我们有时又因为某些原因不想用JPA提供的分页功能,或者他提供的分页功能还不能满足我们特定的需求,那么就需要自定义我们的查询,方法如下:
- /**
- *
- * ClassName: ADTemplateDaoSpecific <br/>
- * Reason: TODO 该接口为模板的CRUD操作的自定义特制接口. <br/>
- * date: 2015年7月6日 上午10:12:43 <br/>
- *
- * @author whc
- * @version 1.0
- * @since JDK 1.8
- */
- interface ADTemplateDaoSpecific{
- /**
- *
- * findAllByPageNum:根据分页查询模板资料. <br/>
- *
- * @author whc
- * @param start
- * @param end
- * @return
- * @since JDK 1.8
- */
- public List<ADTemplate> findAllThroughPageNum(int start,int end) ;
- }
- /**
- *
- * ClassName: ADTemplateDaoSpecificImpl <br/>
- * Reason: TODO 模板的CRUD操作的自定义特制接口的实现类. <br/>
- * date: 2015年7月9日 下午3:53:43 <br/>
- *
- * @author whc
- * @version 1.0
- * @since JDK 1.8
- */
- @Repository
- class ADTemplateDaoImpl implements ADTemplateDaoSpecific{
-
- @PersistenceContext
- private EntityManager entityManager;
- /**
- * TODO 分页查询.
- * Ps:JPA不支持limit关键字
- * @see com.iot.fileDownLoad.dao.ADTemplateDaoSpecific#findAllByPageNum(int, int)
- */
- public List<ADTemplate> findAllThroughPageNum(int start, int end) {
- StringBuffer sql = new StringBuffer("from ADTemplate where isDelete = '0'");
-
- javax.persistence.Query query = entityManager.createQuery(sql.toString());
-
- query.setFirstResult(start);
- query.setMaxResults(end);
- return query.getResultList();
- }
- }
注意,此时需要使用@PersistentContext注解注入EntityManager。然后在实现类中我们就可以利用它来实现分页。
JPA坑2:函数的命名必须规范
可以知道,JPA的原理主要是靠函数的命名。所以就要求我们的DAO层函数名字十分的规范,注意点有2:
一是:命名的驼峰法则,如 userInfo , myCar 这样等。
二是:命名的时候注意有Byxxx,其中这个xxx最好是该实体的属性,比如说
这样的名字就可以知道是根据id来查询。
public List<TemplatePath> getTemplatePathByTemplateId(@Param("id")int id);
这样的名字就可以知道是根据id来查询。
相关文章
- s2sh框架搭建(辅助工具:MyEclipse)及解决一些遇到的问题
- Pytorch Lightning【在Pytorch基础上进行封装的库,为了让用户能够脱离PyTorch一些繁琐的细节,专注于核心代码的构建,提供了许多实用工具,可以让实验更加高效】
- python一些开源特色库
- 页面设计的一些规范
- mysql的一些基本常识(约束 、事务,事务隔离级别)
- 2017视频监控趋势的一些思考
- 写毕业设计论文或写书关于参考文献的一些原则
- DjangoAdmin后台的一些设置
- 数学建模竞赛的一些心得体会
- c语言中qsort函数的使用、编程中的一些错误
- 浅谈Android Fragment嵌套使用存在的一些BUG以及解决方法
- 关于在移动平台读取unity资源目录文件的一些小问题
- Go语言的指针的一些测试
- webpy,希望能多了解一些关于WSGI,PYTHON的WEB开发框架的事,也希望能进一步了解PYTHON