生活随笔
收集整理的這篇文章主要介紹了
jpa 总结
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
轉(zhuǎn):http://blog.csdn.net/linzhiqiang0316/article/details/52639265
先來介紹一下JPA中一些常用的查詢操作:
?
[java]?view plain
?copy ??public?List<User>?findByHeightAndSex(int?height,char?sex);?????public?List<User>?findByHeightOrSex(int?height,char?sex);??????public?List<User>?findByHeightBetween(int?min,int?max);??????public?List<User>?findByHeightLessThan(int?max);??????public?List<User>?findByHeightGreaterThan(int?min);??????public?List<User>?findByNameIsNull();??????public?List<User>?findByNameIsNotNull();??????public?List<User>?findByNameNotNull();??????public?List<User>?findByNameLike(String?name);??????public?List<User>?findByNameNotLike(String?name);??????public?List<User>findByNameNotNullOrderByHeightAsc();??????public?List<User>?findByNameNot(String?name);??????public?List<User>?findByNameIn(String?name);??????public?List<User>?findByNameNotIn(String?name);?? JPA中的風(fēng)格就是這樣,每個(gè)方法其實(shí)都是一條SQl命令,通過一些關(guān)鍵字就可以實(shí)現(xiàn)SQL中類似于like in等等之類的命令了。
?
最重要的是我們再開發(fā)的過程中,只需要編寫dao中一個(gè)個(gè)方法,不需要我們編寫dao的實(shí)現(xiàn)類,這樣就可以大大的挺高代碼的復(fù)用率、提高我們的開發(fā)效率。
說道這里不免會有人會問,那一些比較復(fù)雜的關(guān)聯(lián)查詢要怎么實(shí)現(xiàn)呢,JPA的處理方法是:利用原生的SQl命令來實(shí)現(xiàn)那些復(fù)雜的關(guān)聯(lián)查詢,下面就來看下案例。
?
[java]?view plain
?copy ???@Query(value?=?"select?o.*?from?orders?o?,user?u?where?o.uid=u.id?and?u.name=?1",?nativeQuery?=?true)?????@Modifying?????public?List<Order>?findOrderByName(String?name);??????????@Query(value?=?"delete?from?orders?where?id=?1?",?nativeQuery?=?true)?????@Modifying?????public?void?deleteOrderById(int?id);??????????@Query(value?=?"delete?from?orders?where?uid=?1?",?nativeQuery?=?true)?????@Modifying?????public?void?deleteOrderByUId(int?uid);??????????@Query(value?=?"update?orders?set?name=?1?where?id=?2?",?nativeQuery?=?true)?????@Modifying?????public?void?updateOrderName(String?name,int?id);??????????@Query(value?=?"insert?into?orders(name,uid)?value(?1,?2)",?nativeQuery?=?true)?????@Modifying?????public?void?insertOrder(String?name,int?uid);?? 上面的案例中給出了,利用JPA實(shí)現(xiàn)原生的SQL操作,可以很方便的進(jìn)行數(shù)據(jù)庫表的操作。
所以如果是那種查詢語句不是非常復(fù)雜,對查詢時(shí)間要求不是特別苛刻的項(xiàng)目,完全可以采用JPA來進(jìn)行項(xiàng)目的開發(fā)。
?
下面接著來介紹JPA是怎么實(shí)現(xiàn)分頁的效果,其實(shí)JPA脫胎于hibernate,所以本身就對分頁功能有很好的支持。下面給出具體例子:
?
[java]?view plain
?copy Page<User>?findByNameNot(String?name,Pageable?pageable);?? [java]?view plain
?copy @RequestMapping(value?=?"/params",?method=?RequestMethod.GET)?????@ResponseBody?????public?String?getEntryByParams(@RequestParam(value?=?"name",?defaultValue?=?"林志強(qiáng)")?String?name,?@RequestParam(value?=?"page",?defaultValue?=?"0")?Integer?page,?@RequestParam(value?=?"size",?defaultValue?=?"15")?Integer?size)?{?????????Sort?sort?=?new?Sort(Sort.Direction.DESC,?"id");?????????Pageable?pageable?=?new?PageRequest(page,?size,?sort);?????????Page<User>?pages=userDao.findByNameNot(name,pageable);?????????Iterator<User>?it=pages.iterator();?????????while(it.hasNext()){?????????????System.out.println("value:"+((User)it.next()).getId());?????????}?????????return?"success...login....";?????}?? 上面的代碼一個(gè)是在dao層中的,一個(gè)是在controller中的。
?
dao層中添加一個(gè)返回值為Page,參數(shù)值為Pageable。controller層中通過實(shí)例化Pageable這個(gè)類,然后調(diào)用dao層這個(gè)分頁方法。
通過這些步驟就可以輕輕松松的實(shí)現(xiàn)分頁的效果啦,看起來是不是特別方便。
最后在給大家介紹一下JPA是如何實(shí)現(xiàn)事務(wù)操作的。其實(shí)因?yàn)镾pringBoot中已經(jīng)對事務(wù)做了很好的封裝了,使用起來特別方便。下面看一下案例:
?
[java]?view plain
?copy @RequestMapping("/saveOrder")??@ResponseBody??@Transactional()??public?String?saveOrder(){??????Order?o1=new?Order("11",2);??????Order?o2=new?Order("22",2);??????Order?o3=new?Order("33",2);??????Order?o4=new?Order("44",2);??????orderDao.save(o1);??????orderDao.save(o2);??????orderDao.save(o3);??????orderDao.save(o4);??????return?"successfull....saveOrder......";??}?? 只要在方法的上面加上@Transaction?這個(gè)注解就可以輕輕松松的實(shí)現(xiàn)事務(wù)的操作了,是不是特別方便啊。
?
不過這里有幾點(diǎn)需要注意的是:
1.這個(gè)注解實(shí)現(xiàn)的事務(wù)管理器是默認(rèn)的,如果不想要默認(rèn)是事務(wù)管理器,可以自己進(jìn)行添加,我這里就不多介紹了。
2.事務(wù)的隔離級別也是可以自己設(shè)置的,具體請看這篇博客?點(diǎn)擊打開鏈接
3.事務(wù)的傳播行為也是可以自己設(shè)置的,具體請看這篇博客點(diǎn)擊打開鏈接
轉(zhuǎn)載于:https://www.cnblogs.com/yanghongfei/p/8288438.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)
總結(jié)
以上是生活随笔為你收集整理的jpa 总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。