spring boot中nativeQuery的用法
spring boot就是一個大框架里面包含了許許多多的東西,其中spring就是最核心的內容之一,當然就包含spring mvc。spring mvc 是只是spring 處理web層請求的一個模塊。
因此他們的關系大概就是這樣:spring mvc < spring <springboot。
Spring框架概述什么是SpringSpring是一個開源框架,Spring是于2003 年興起的一個輕量級的Java 開發(fā)框架,由Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》。Spring是為了解決企業(yè)級應用開發(fā)的復雜性而創(chuàng)建的,使用Spring可以讓簡單的JavaBean實現(xiàn)之前只有EJB才能完成的事情。但是Spring不僅僅局限于服務器端開發(fā),任何Java應用都能在簡單性、可測試性和松耦合性等方面從Spring中獲益。
nativeQuery = true的作用當語句中有 nativeQuery = true時, @Query中的sql語句可以為自己手寫的原生sql,并且寫的原生sql是可以執(zhí)行的,例如:
@Query(value = 'select u.username,u.password from t_user u where u.username = ?1 and u.password = ?2', nativeQuery = true) List<User> findByZH(String username, String password);
當執(zhí)行@Query時,會將該'select u.username,u.password from t_user u where u.username = ?1 and u.password = ?2'拷貝到數(shù)據(jù)庫,并填充占位符。但是執(zhí)行語句時,有一個要求就是語句中的表名(t_user)和字段名(username,password)必須為數(shù)據(jù)庫中的表名和字段名,
當沒有nativeQuery = true時,@Query中value值的sql語句就只能按照規(guī)范來寫。否則就會報錯
Error creating bean with name ’userMapper’ defined in com.example.demo.dao.UserMapper defined in @EnableJpaRepositories declared on JpaRepositoriesRegistrar
規(guī)范就是:表名必須是所寫的實體類名,字段名也必須是實體類中的自定義的變量名,例如:
@Query(value = 'select u.userName from User u where u.userName = ?1') List<User> findByUserName(String username);
到此這篇關于spring boot中nativeQuery的作用的文章就介紹到這了,更多相關spring boot中nativeQuery內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. 使用EF Code First搭建簡易ASP.NET MVC網站并允許數(shù)據(jù)庫遷移2. 使用PHP實現(xiàn)實時數(shù)據(jù)可視化功能的示例詳解3. Python從文件中讀取數(shù)據(jù)的方法步驟4. XMLHTTP下載遠程數(shù)據(jù)輸出到瀏覽器5. PHP擴展類型及安裝方式解析6. Python pygame實現(xiàn)中國象棋單機版源碼7. 如何在瀏覽器端加密——使用Javascript加密解密8. PHP對文本數(shù)據(jù)庫的基本操作方法9. Vue父組件向子組件傳值以及data和props的區(qū)別詳解10. 基于JavaScript實現(xiàn)留言板功能
