日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Data JPA使用JPQL與原生SQL進(jìn)行查詢的操作

瀏覽:115日期:2023-07-10 14:43:47
1、使用JPQL語句進(jìn)行查詢

JPQL語言(Java Persistence Query Language)是一種和SQL非常類似的中間性和對象化查詢語言,它最終會被編譯成針對不同底層數(shù)據(jù)庫的SQL語言,從而屏蔽不同數(shù)據(jù)庫的差異。

JPQL語言通過Query接口封裝執(zhí)行,Query 接口封裝了執(zhí)行數(shù)據(jù)庫查詢的相關(guān)方法。調(diào)用 EntityManager 的 Query、NamedQuery 及 NativeQuery 方法可以獲得查詢對象,進(jìn)而可調(diào)用Query接口的相關(guān)方法來執(zhí)行查詢操作。

JPQL是面向?qū)ο筮M(jìn)行查詢的語言,可以通過自定義的JPQL完成UPDATE和DELETE操作。JPQL不支持使用INSERT。對于UPDATE或DELETE操作,必須使用注解 @Modifying 進(jìn)行修飾。

【示例】使用JPQL語言進(jìn)行查詢

package com.pjb.jpauserdemo.dao; import com.pjb.jpauserdemo.entity.UserInfo;import org.springframework.data.jpa.repository.JpaRepository;import org.springframework.data.jpa.repository.Modifying;import org.springframework.data.jpa.repository.Query;import org.springframework.data.repository.query.Param;import org.springframework.stereotype.Repository;import java.util.List; /** * 用戶信息數(shù)據(jù)庫訪問接口 * 使用JPQL語言 * @author pan_junbiao **/@Repositorypublic interface UserJpqlDao extends JpaRepository<UserInfo,Integer>{ /** * 根據(jù)用戶姓名,查詢用戶信息 */ @Query('SELECT u FROM UserInfo u WHERE u.userName = ?1') public UserInfo getUserInfoByName(String name); /** * 根據(jù)用戶姓名,模糊查詢用戶列表 */ @Query('SELECT u FROM UserInfo u WHERE u.userName like %:name%') public List<UserInfo> getUserListByName(String name); /** * 修改用戶姓名 */ @Modifying @Query('UPDATE UserInfo u SET u.userName = :name WHERE u.userId = :id') public int updateUserName(@Param('id')int userId, @Param('name')String userName);}2、使用原生SQL語句進(jìn)行查詢

在使用原生SQL查詢時,也使用@Query注解。此時,nativeQuery參數(shù)需要設(shè)置為true。

【示例】使用原生SQL語句進(jìn)行查詢

package com.pjb.jpauserdemo.dao;import com.pjb.jpauserdemo.entity.UserInfo;import org.springframework.data.jpa.repository.JpaRepository;import org.springframework.data.jpa.repository.Modifying;import org.springframework.data.jpa.repository.Query;import org.springframework.data.repository.query.Param;import org.springframework.stereotype.Repository;import org.springframework.transaction.annotation.Transactional;import java.util.List; /** * 用戶信息數(shù)據(jù)庫訪問接口測試類 * 使用原生SQL語言 * @author pan_junbiao **/@Repositorypublic interface UserSqlDao extends JpaRepository<UserInfo,Integer>{ /** * 根據(jù)用戶ID,獲取用戶信息 */ @Query(value = 'SELECT * FROM tb_user WHERE user_id = :id',nativeQuery = true) public UserInfo getUserById(@Param('id')int userId); /** * 根據(jù)用戶姓名,模糊查詢用戶列表 */ @Query(value = 'SELECT * FROM tb_user WHERE user_name LIKE %:userName%',nativeQuery = true) public List<UserInfo> getUserListByName(@Param('userName')String userName); /** * 修改用戶姓名 */ @Modifying @Query(value = 'UPDATE tb_user SET user_name = :name WHERE user_id = :id',nativeQuery = true) public int updateUserName(@Param('id')int userId, @Param('name')String userName);}

可以看到,@Query與@Modifying這兩個注解一起聲明,可以定義個性化更新操作。

Spring data jpa@query使用原生SQl,需要注意的坑

根據(jù)代碼來解說:

@Query(value = 'select bill.id_ as id, bill.created_date as date, bill.no, lawyer_case .case_no as caseNo, ' + 'lawyer_case .case_name as caseName, customer.no as customerNo, customer.cn_name as customerName, ' + 'bill.total_expense_after_tax, bill.collected_money, bill.book_ticket_amount, bill.version ' + 'e1.name as creator, bill.status' + 'from bill ' + 'left join lawyer_case on lawyer_case .case_no=bill.case_no ' + 'left join customer on customer.no=bill.customer_no ' + 'left join employee e1 on e1.id_=bill.creator ' + 'where IF (?1!=’’, customer_no=?1, 1=1) ' + 'and IF (?2!=’’, case_no=?2, 1=1) ' + 'and IF (?3!=’’, status=?3, 1=1) ' + 'and IF (?4!=’’, creator’%’,?4,’%’)), 1=1) ' + 'and create_by=?5 ' + 'ORDER BY ?#{#pageable} ', countQuery = 'select count(*) ' + 'from bill ' + 'left join lawyer_case on lawyer_case .case_no=bill.case_no ' + 'left join customer on customer.no=bill.customer_no ' + 'left join employee e1 on e1.id_=bill.creator ' + 'where IF (?1!=’’, customer_no=?1, 1=1) ' + 'and IF (?2!=’’, case_no=?2, 1=1) ' + 'and IF (?3!=’’, status=?3, 1=1) ' + 'and IF (?4!=’’, creator’%’,?4,’%’)), 1=1) ' + 'and create_by=?5 '+ 'ORDER BY ?#{#pageable} ', nativeQuery = true) Page<Object[]> findAllBill(String customerNo, String caseNo, Integer status, String creator, String createBy, Pageable pageable);需要注意的方法有以下幾點:

1、From 不支持重命名.

2、返回的是一個page<Object[]>,數(shù)組中只保存了數(shù)據(jù),沒有對應(yīng)的key,只能根據(jù)返回數(shù)據(jù)的順序,依次注入到DTO中。

3、對于使用分頁,需要:“ORDER BY ?#{#pageable}”,可以直接傳入一個pageable對象,會自動解析。

4、注意格式問題,很多時候就是換行的時候,沒有空格。

5、仔細(xì)對應(yīng)數(shù)據(jù)庫中表字段,很多時候報某個字段找不到,就是因為字段名寫錯,和數(shù)據(jù)庫中對應(yīng)不上。

6、這是解決使用微服務(wù),大量的數(shù)據(jù)都需要遠(yuǎn)程調(diào)用,會降低程序的性能。

7、使用Pageabel作為參數(shù)的時候,去進(jìn)行分頁。剛開始的時候,覺得還是一個可行的辦法,但是得注意的時候,當(dāng)需要排序的時候,是無法加入sort字段的。 會一直報錯left*。

8、針對7的解決方案,把原生SQL的數(shù)據(jù)查詢和countQuery分成兩個查詢方法。得到count,然后進(jìn)行判斷,若是等于0,則直接返回空集合;反之,則取獲取數(shù)據(jù)。 需要自己進(jìn)行分頁計算,傳入正確的pageNumber和pageSize。 大部分系統(tǒng)都是按照修改時間進(jìn)行降序排序。 所以,order by可以寫死。然后pageNumber和pageSize動態(tài)傳入。 pageNumber的算法= (pageNumber - 1) * pageSize, 前提是PageNumber是從1開始,若0,則pageNumber=pageNumber * PageSize; 這樣就可以保證數(shù)據(jù)的正確。

/*** pageInfos: 轉(zhuǎn)換之后的數(shù)據(jù)。* pageable:傳入的pageable.* totalPage: 第一條SQL算好的返回值。* 這樣就可以統(tǒng)一的返回各種pageDTO。*/private Page<T> convertForPage(List<T> pageInfos, Pageable pageable, Integer totalPage) {return new PageImpl<>(pageInfos, pageable, totalPage); }

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
婷婷综合社区| 亚洲人妖在线| 成人午夜亚洲| 日韩精品免费一区二区三区| 欧美日韩国产v| 欧美国产91| 另类激情亚洲| 久久先锋影音| 国产日韩精品视频一区二区三区| 国产欧美亚洲精品a| 鲁鲁在线中文| 午夜在线精品偷拍| 国产精品s色| 丝袜av一区| 亚洲人成高清| 91视频一区| 99国产一区| 国产精品片aa在线观看| 成人va天堂| 亚洲精品人人| 国产+成+人+亚洲欧洲在线| 在线综合视频| 国产精品一国产精品k频道56| 亚洲电影有码| 欧美偷窥清纯综合图区| 婷婷综合六月| 亚洲精品日韩久久| 四虎国产精品免费观看| 国产亚洲欧洲| 精品少妇一区| 在线观看亚洲精品福利片| 久久中文字幕一区二区三区| 午夜日韩av| 欧美a一区二区| 亚洲一区欧美| 亚洲成人精品| 久久精品理论片| 91久久黄色| 国产一区二区三区亚洲| 蜜臀久久99精品久久久久久9 | 日韩伦理在线一区| 欧美亚洲人成在线| 午夜欧美在线| 欧美国产亚洲精品| 六月天综合网| 日本国产精品| 精品亚洲免a| 日本午夜精品久久久久| 欧美日韩一区二区综合| 国产精品巨作av| 亚洲成人一区| 麻豆精品视频在线| 日韩欧美精品一区二区综合视频| 久久高清精品| 国内揄拍国内精品久久| 天堂俺去俺来也www久久婷婷| 欧美精品高清| 精品久久美女| 欧美日韩夜夜| 蜜臀av国产精品久久久久 | 国产欧美视频在线| 六月天综合网| 亚洲精品电影| 亚洲一区资源| 精品视频自拍| 国产激情综合| 日韩中文字幕在线一区| 91国语精品自产拍| 国产传媒在线观看| 国产精品99精品一区二区三区∴ | 国产精品观看| 91精品国产经典在线观看| 亚洲综合欧美| 亚洲激情社区| 欧美二区视频| 三级精品视频| 国产在线|日韩| 热三久草你在线| 国产成年精品| 国产不卡av一区二区| 你懂的亚洲视频| 嫩呦国产一区二区三区av| 国产欧美日韩| 国产精品亚洲四区在线观看| 日韩va欧美va亚洲va久久| 亚洲一区二区免费看| 国产一区成人| 日韩中文字幕不卡| 中文字幕日韩高清在线 | 亚洲啊v在线| 日韩在线欧美| 91精品国产乱码久久久久久久| 在线天堂资源www在线污| 国产精品久久久久蜜臀| 精品久久在线| 国产精品精品| 日韩国产综合| 欧美日韩精品在线一区| 欧美~级网站不卡| 久热综合在线亚洲精品| 亚洲精品福利| 国产伦一区二区三区| 日韩精品福利一区二区三区| 欧美日韩1区2区3区| 国产激情精品一区二区三区| 精品视频亚洲| 久久精品99久久无色码中文字幕| 红桃视频亚洲| 亚洲91在线| 国产精品久久久久久模特| 成人午夜亚洲| 亚洲精品一区二区在线看| 麻豆精品91| 久久国产尿小便嘘嘘| 国产成人精选| 狠狠干成人综合网| 日韩欧美美女在线观看| 日本不卡一二三区黄网| 久久久久亚洲精品中文字幕| 久久视频国产| 日产欧产美韩系列久久99| 麻豆高清免费国产一区| 欧美精品资源| 亚州av一区| 国产日韩电影| 亚洲精品护士| sm捆绑调教国产免费网站在线观看| 日韩精品一区二区三区免费观看| 蜜桃视频一区二区三区在线观看| 国产精品综合| 亚洲a在线视频| 日本中文字幕不卡| 精品一区二区三区中文字幕视频 | 日韩综合一区| 免费美女久久99| 麻豆成人在线观看| 欧美大黑bbbbbbbbb在线| 欧美亚洲国产日韩| 日本精品不卡| 日韩国产在线不卡视频| 高清日韩中文字幕| 蜜芽一区二区三区| 黄色精品视频| 视频一区国产视频| 色欧美自拍视频| 亚洲色图国产| 日韩欧美午夜| 少妇高潮一区二区三区99| av高清不卡| 久久国产精品色av免费看| 久久一级电影| 精品一区二区三区免费看| 日韩精品一二三四| 色爱综合网欧美| 亚洲ww精品| 亚洲特色特黄| 久久午夜影院| 日韩激情视频网站| 欧美日韩黑人| 精品视频99| 亚洲最大av| 国产盗摄——sm在线视频| 日韩精品一区二区三区中文在线| 欧美三区四区| 国产精品成人国产| 中文一区一区三区免费在线观| 午夜久久中文| 欧美aⅴ一区二区三区视频| 蜜臀久久99精品久久久久宅男| 日韩美女一区二区三区在线观看| 欧美日韩91| 亚洲欧洲专区| 国产亚洲激情| 香蕉人人精品| 国产传媒在线观看| 国产欧美一区二区三区米奇| 久久大逼视频| 午夜久久一区| 欧美日韩一二三四| 日韩三区免费| 日韩激情一区| 正在播放日韩精品| 国产成人精品一区二区三区在线| 国产伦一区二区三区| 日韩在线观看中文字幕| 夜夜嗨网站十八久久| 久久久精品日韩| zzzwww在线看片免费| 国产日产一区| 日本99精品| 日韩在线a电影| 宅男噜噜噜66国产日韩在线观看| 999国产精品| 性欧美xxxx免费岛国不卡电影| 在线手机中文字幕| 亚洲伦乱视频| 99久久夜色精品国产亚洲1000部| 日韩精品中文字幕第1页| 精品国产免费人成网站| 黄色aa久久|