您好,登錄后才能下訂單哦!
Spring Data的JDBC的作用是什么,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
首先,我們需要一個實體:
class Customer { @Id Long id; String firstName; LocalDate dob; }
請注意,不需要getter或setter。如果您意,可以增加。實際上,唯一的要求是實體有一個注釋的屬性Id(即@org.springframework.data.annotation.Id,注意不是javax.persistence,后者是JPA)。
接下來,我們需要聲明一個存儲庫。最簡單的方法是擴展CrudRepository:
interface CustomerRepository extends CrudRepository<Customer, Long> {}
最后,我們需要配置ApplicationContext以啟用存儲庫的創建:
@Configuration @EnableJdbcRepositories (1) public class CustomerConfig extends JdbcConfiguration { (2) @Bean NamedParameterJdbcOperations operations() { (3) return new NamedParameterJdbcTemplate(dataSource()); } @Bean PlatformTransactionManager transactionManager() { (4) return new DataSourceTransactionManager(dataSource()); } @Bean DataSource dataSource(){ (5) return new EmbeddedDatabaseBuilder() .generateUniqueName(true) .setType(EmbeddedDatabaseType.HSQL) .addScript("create-customer-schema.sql") .build(); } }
讓我們一步一步地解釋。
1. EnableJdbcRepositories可以創建存儲庫。由于它需要存在一些bean,我們需要其余的配置。
2. 繼承擴展的JdbcConfiguration將一些默認bean添加到ApplicationContext。可以覆蓋其方法以自定義Spring Data JDBC的某些行為。現在,我們使用默認實現。
3. 真正重要的部分是NamedParameterJdbcOperations,它在內部用于向數據庫提交SQL語句。
4. 嚴格來說,事務管理器不是必需的。不支持跨越多個SQL語句的事務。
5. Spring Data JDBC沒有直接使用DataSource,但是,由于TransactionManager和NamedParameterJdbcOperations需要,將DataSource注冊為bean是一種確保兩者使用相同實例的簡單方法。
這就是一切。現在讓我們測試玩玩:
@RunWith(SpringRunner.class) @Transactional @ContextConfiguration(classes = CustomerConfig.class) public class CustomerRepositoryTest { @Autowired CustomerRepository customerRepo; @Test public void createSimpleCustomer() { Customer customer = new Customer(); customer.dob = LocalDate.of(1904, 5, 14); customer.firstName = "Albert"; Customer saved = customerRepo.save(customer); assertThat(saved.id).isNotNull(); saved.firstName = "Hans Albert"; customerRepo.save(saved); Optional<Customer> reloaded = customerRepo.findById(saved.id); assertThat(reloaded).isNotEmpty(); assertThat(reloaded.get().firstName).isEqualTo("Hans Albert"); } }
@Query 注解
你可能不會只使用基本的CRUD方法CrudRepository。可以使用簡單的@Query注釋來指定存儲庫方法的查詢:
@Query("select id, first_name, dob from customer where upper(first_name) like '%' || upper(:name) || '%' ") List<Customer> findByName(@Param("name") String name);
請注意,@Param如果使用-parameters標志進行編譯,則不需要注釋。
如果要執行更新或刪除語句,可以使用@Modifying向方法添加注釋。
讓我們創建另一個測試以試用新方法。
@Test public void findByName() { Customer customer = new Customer(); customer.dob = LocalDate.of(1904, 5, 14); customer.firstName = "Albert"; Customer saved = customerRepo.save(customer); assertThat(saved.id).isNotNull(); customer.id= null; (1) customer.firstName = "Bertram"; customerRepo.save(customer); customer.id= null; customer.firstName = "Beth"; customerRepo.save(customer); assertThat(customerRepo.findByName("bert")).hasSize(2); (2)
關于Spring Data的JDBC的作用是什么問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。