@Query注解
@Query注解使用起來很簡單,默認的屬性是value,就是當前寫的SQL語句,有時會用到nativeQuery屬性,這個屬性是用來標記當前的SQL是本地SQL,還是符合JPA語法規(guī)范的SQL。這里需要解釋一下本地SQL和JPA語法規(guī)范的SQL區(qū)別。
本地SQL,是根據(jù)實際使用的數(shù)據(jù)庫類型寫的SQL,這種SQL中使用到的一些語法格式不能被JPA解析以及可能不兼容其他數(shù)據(jù)庫,這種SQL稱為本地SQL,此時需要將nativeQuery屬性設置為true,否則會報錯。
JPA語法規(guī)范的SQL,往往這種SQL本身是不適用于任何數(shù)據(jù)庫的,需要JPA將這種SQL轉換成真正當前數(shù)據(jù)庫所需要的SQL語法格式。
注意:JPA很好的一個特性就是用JPA語法規(guī)范寫的SQL,會根據(jù)當前系統(tǒng)使用的數(shù)據(jù)庫類型改變生成的SQL語法,兼容數(shù)據(jù)庫類型的切換,如之前使用的是MySQL,現(xiàn)在換成Oracle,由于不同類型的數(shù)據(jù)庫,SQL語法會有區(qū)別,如果使用的是mybatis,就需要手動去改SQL兼容Oracle,而JPA就不用啦,無縫對接。
說明:很大的時候使用JPA感覺都是為了兼容后期可能會有數(shù)據(jù)庫切換的問題,所以在使用JPA的時候,不要去使用本地SQL,這就違背了使用JPA的初衷,讓nativeQuery屬性保持默認值就可以啦!