JPA的一些坑

推荐一篇比较好的介绍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最好是该实体的属性,比如说
public List<TemplatePath> getTemplatePathByTemplateId(@Param("id")int id);

这样的名字就可以知道是根据id来查询。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值