模糊查詢
Spring Data Jpa的使用可以減少開發者對sql語句的編寫,甚至完全不需要編寫sql語句。但是,開發過程中總會遇到各種復雜的場景以及大大小小的坑。
今天項目中某個功能模塊需要用到模糊查詢。原生sql中模糊查詢關鍵字‘Like',而Spring Data Jpa的Repository接口中恰恰也有實體字段對應的Like。但是,如果直接使用它,那么恭喜你,你幸運地掉坑了。
Spring Data Jpa 模糊查詢正確用法
首先,我們先創建一個實體用來存儲我們的數據
/** * 實體 * * @author chentai * @date 18/04/22 */@Data@Entity@EqualsAndHashCode(callSuper = true)public class ExampleEntity{ @Id @GeneratedValue(generator = "uuid") @GenericGenerator(name = "uuid", strategy = "uuid") private String Id ; private String username; private String deviceNames;}
接著,創建我們實體對應的Repository接口
/** * @author chentai * @date 18/04/22 */@Repositorypublic interface ExampleRepository extends CrudRepository<ExampleEntity, String> { /** * 模糊查詢正確用法 * 其中username不支持模糊查詢,deviceNames支持模糊查詢 * * @param deviceNames 模糊查詢deviceNames * @param username 用戶名稱 * @return {@link List<ExampleEntity>} */ List<ExampleEntity> findAllByDeviceNamesContainingAndUsername(String deviceNames,String username); /** * 模糊查詢錯誤用法 * 其中username不支持模糊查詢,deviceNames支持模糊查詢 * * @param deviceNames 模糊查詢deviceNames * @param username 用戶名稱 * @return {@link List<ExampleEntity>} */ List<ExampleEntity> findAllByDeviceNamesLikeAndUsername(String deviceNames,String username); }
最后,在測試類中測試ExampleRepository中的兩個方法,(測試結果暫不展示)發現findAllByDeviceNamesLikeAndUsername方法并沒有正確查詢到我們想要的結果,得到的結果是精確查詢的結果。而findAllByDeviceNamesContainingAndUsername得到了我們想要的模糊查詢的結果。
總結
如果想要在項目中不編寫sql原生語句的情況下使用模糊查詢,請使用Containing關鍵字,而非想當然的認為原生使用Like關鍵字,JPA中也是使用Like關鍵字。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答
圖片精選