9-SQL database

spring boot 內(nèi)嵌數(shù)據(jù)庫(kù)支持

內(nèi)存數(shù)據(jù)庫(kù)不能提供數(shù)據(jù)持久化风喇,但用于測(cè)試很方便;Spring boot自動(dòng)配置的內(nèi)嵌數(shù)據(jù)庫(kù)包括H2,HSQL,Derby属百。不需要使用任何連接數(shù)據(jù)庫(kù)的URL强经,只需添加要使用的內(nèi)嵌數(shù)據(jù)庫(kù)依賴就可以婿禽。例如:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
  <groupId>org.hsqldb</groupId>
  <artifactId>hsqldb</artifactId>
  <scope>runtime</scope>
</dependency>

內(nèi)嵌數(shù)據(jù)庫(kù)需要使用Spring-jdbc依賴眼滤,但是spring-boot-starter-data-jpa已經(jīng)包含巴席,所以不需要額外添加。
如果不在Srping boot中使用則對(duì)應(yīng)maven配置如下:

<dependency>
      <groupId>org.springframework.data</groupId>
      <artifactId>spring-data-releasetrain</artifactId>
      <version>Lovelace-RELEASE</version>
      <scope>import</scope>
      <type>pom</type>
</dependency>
配置數(shù)據(jù)源

Spring boot使用如下策略選擇數(shù)據(jù)庫(kù)連接池:
1诅需,如果HikariCP可用的話漾唉,更傾向使用HikariCP荧库,提供更好的性能和并發(fā);
2赵刑,如果Tocmat DataSource鏈接池存在分衫,HikariCp不存在,則使用Tomcat DataSource般此;
3蚪战,如果以上兩個(gè)均不存在,如果Commons DBCP2存在則使用铐懊。
如果在Spring boot中使用spring-boot-starter-jdbc或則使用spring-boot-starter-data-jpa起步依賴屎勘,會(huì)自動(dòng)添加HikariCP依賴【影牵可以使用spring.datasource.type配置指定數(shù)據(jù)庫(kù)鏈接池。
數(shù)據(jù)源的配置使用額外的配置屬性丑慎,使用前綴spring.datasource.*喜喂,例如:

spring.datasource.url=jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.datasource.username=root  
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

如果使用HikariCP,可以使用spring.datasource.hikari.指定特定屬性配置竿裂;如果tomcat pool可以使用spring.datasource.tomcat.配置玉吁。

使用數(shù)據(jù)源

Spring的JdbcTemplate和NamedParameterJdbcTemplate會(huì)自動(dòng)配置,通過(guò) @Autowire注解可以直接在Bean中使用腻异。例如:

@Component
public class UserDao{
        @Autowired
    private final JdbcTemplate jdbcTemplate;
    // ...
}
spring-data-jpa

通過(guò)Spring jpa可以實(shí)現(xiàn)定義interface查詢數(shù)據(jù)庫(kù)进副,即根據(jù)方法名自動(dòng)生成sql語(yǔ)句,而不需要寫(xiě)具體查詢語(yǔ)句悔常。Spring 提供的接口有以下幾個(gè):
org.springframework.data.repository.Repository<T, ID>
org.springframework.data.repository.CrudRepository<T, ID>
org.springframework.data.repository.PagingAndSortingRepository<T, ID>
org.springframework.data.jpa.repository.JpaRepository<T, ID>
其中CrudRepository繼承自Repository影斑,PagingAndSortingRepository繼承自CrudRepository,JpaRepository繼承自PagingAndSortingRepository和QueryByExampleExecutor接口机打,定義的方法名稱根據(jù)規(guī)則就可以實(shí)現(xiàn)自動(dòng)生成sql語(yǔ)句矫户。
為了實(shí)現(xiàn)幾個(gè)不同的接口,先定義的一個(gè)Person Entity

@Entity(name="person")
public class Person implements Serializable{

    private static final long serialVersionUID = 1L;
    
    @Id
    private String id;
    @Column(name="name")
    private String name;
    @Column(name="password")
    private String password;
    
    @Column(name="country")
    private String country;
    @Column(name="city")
    private String city;
    @Column(name="street")
    private String street;
      // setter getter 省略
        ....
}
實(shí)現(xiàn)CrudRepository接口

創(chuàng)建PersonCrudRepository接口残邀,并定義部分查詢方法

@Repository
public interface PersonCrudRepository extends CrudRepository<Person,String>{

    public Person save(Person person);
    
    public Person findPersonById(String id);
    
    public List<Person> findPersonByName(String name);

    public List<Person> findPersonByCity(String city);
    
}
實(shí)現(xiàn)PagingAndSortingRepository

以同樣方法創(chuàng)建PersonPagingAndSortingRepository接口

@Repository
public interface PersonPagingAndSortingRepository extends PagingAndSortingRepository<Person, String>{

    
}
實(shí)現(xiàn)JpaRepository接口

創(chuàng)建PersonJpaRepository接口皆辽,并使用其繼承的Query接口方法定義查詢

@Repository
public interface PersonJpaRepository extends JpaRepository<Person, String>{
    
    public Person save(Person person);
    
    public Person findPersionById(String id);
    
    public List<Person> findPersonByName(String name);
    
    // 允許查詢結(jié)果中取出重復(fù)值
    public List<Person> findDistinctPeopleByNameOrCity(String name, String city);
    public List<Person> findPeopleDistinctByNameOrCity(String name, String city);
    
    // 指定屬性忽略大小寫(xiě)
    public List<Person> findByNameIgnoreCase(String name);
    // 多個(gè)屬性忽略大小寫(xiě)
    public List<Person> findByCityAndCountryAllIgnoreCase(String city, String coutry);

    // 使用order進(jìn)行排序
    public List<Person> findByNameOrderByNameAsc(String name);
    public List<Person> findByCityOrderByCityDesc(String city);
}
自定義Repository接口

使用@NoRepositoryBean注解自定義Repository接口,例如:

@NoRepositoryBean
public interface MyRepository<T,ID extends Serializable> extends Repository<T, ID> {

    Optional<T> findById(ID id);
    
    <S extends T> S save(S entity);
}

自定義Repository的使用方法和Spring中定義的Repository使用方式相同芥挣,例如:

@Repository
public interface MyRepositoryTest extends MyRepository<Person, String>{

}
測(cè)試

不使用內(nèi)置數(shù)據(jù)庫(kù)測(cè)試驱闷,使用自己配置的mysql數(shù)據(jù)。編寫(xiě)測(cè)試用例會(huì)使用如下幾個(gè)注解:
@RunWith(SpringRunner.class)
@DataJpaTest :使用內(nèi)置H2數(shù)據(jù)庫(kù)作為測(cè)試數(shù)據(jù)庫(kù)空免,需要在maven添加對(duì)h2數(shù)據(jù)庫(kù)的支持空另;
@JdbcTest:使用配置數(shù)據(jù)源的庫(kù)作為測(cè)試庫(kù)
@AutoConfigureTestDatabase(replace = Replace.NONE) :使用真實(shí)數(shù)據(jù)源測(cè)試,不使用內(nèi)置數(shù)據(jù)庫(kù)替換蹋砚。通過(guò)Repalce.NONE參數(shù)指定
@TestPropertySource(locations={"classpath:application.properties"}) :指定配置文件位置
@SpringBootTest:指定test class為spring boot test
測(cè)試用例如下:

@RunWith(SpringRunner.class)
@Transactional(propagation = Propagation.NOT_SUPPORTED)
@AutoConfigureTestDatabase(replace = Replace.NONE) 
@TestPropertySource(locations={"classpath:application.properties"}) 
@SpringBootTest
public class PersonCrudRepositoryTest {

    @Autowired
    private PersonCrudRepository personCrudRepository;
    
    @Autowired
    private PersonJpaRepository personjpa;
    
    @Autowired
    private PersonPagingAndSortingRepository personPage;
    
    @Autowired
    private MyRepositoryTest myRepositoryTest;
    
@Test
    public void testSavePerson() {
        
        Person person = new Person();
        person.setId("12345");
        person.setName("zhongzhong90");
        person.setPassword("12345678");
        person.setCountry("china");
        person.setCity("chengdu");
        person.setStreet("雙楠");
        assertNotNull(personCrudRepository.save(person));
        
        Person person2 = new Person();
        person2.setId("123455");
        person2.setName("zhongzhong2");
        person2.setPassword("12345678");
        person2.setCountry("china");
        person2.setCity("chengdu");
        person2.setStreet("雙楠2");
        assertNotNull(personjpa.save(person2));
        
        Person person3 = new Person();
        person3.setId("1234556");
        person3.setName("ZHONGZHONG");
        person3.setPassword("12345678");
        person3.setCountry("china");
        person3.setCity("chengdu");
        person3.setStreet("雙楠2");
        assertNotNull(personPage.save(person3));
        
        Person person4 = new Person();
        person4.setId("123455667");
        person4.setName("ZHONGZHONG2");
        person4.setPassword("12345678");
        person4.setCountry("china");
        person4.setCity("綿陽(yáng)");
        person4.setStreet("雙楠2");
        assertNotNull(myRepositoryTest.save(person4));
    }
      //其他方法省略
     ...
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末痹换,一起剝皮案震驚了整個(gè)濱河市征字,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌娇豫,老刑警劉巖匙姜,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異冯痢,居然都是意外死亡氮昧,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)浦楣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)袖肥,“玉大人,你說(shuō)我怎么就攤上這事振劳∽底椋” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵历恐,是天一觀的道長(zhǎng)寸癌。 經(jīng)常有香客問(wèn)我,道長(zhǎng)弱贼,這世上最難降的妖魔是什么蒸苇? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮吮旅,結(jié)果婚禮上溪烤,老公的妹妹穿的比我還像新娘。我一直安慰自己庇勃,他們只是感情好檬嘀,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著责嚷,像睡著了一般枪眉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上再层,一...
    開(kāi)封第一講書(shū)人閱讀 49,816評(píng)論 1 290
  • 那天贸铜,我揣著相機(jī)與錄音,去河邊找鬼聂受。 笑死蒿秦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蛋济。 我是一名探鬼主播棍鳖,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了渡处?” 一聲冷哼從身側(cè)響起镜悉,我...
    開(kāi)封第一講書(shū)人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎医瘫,沒(méi)想到半個(gè)月后侣肄,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡醇份,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年稼锅,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片僚纷。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡矩距,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出怖竭,到底是詐尸還是另有隱情锥债,我是刑警寧澤,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布痊臭,位于F島的核電站哮肚,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏趣兄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一悼嫉、第九天 我趴在偏房一處隱蔽的房頂上張望艇潭。 院中可真熱鬧,春花似錦戏蔑、人聲如沸蹋凝。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鳍寂。三九已至,卻和暖如春情龄,著一層夾襖步出監(jiān)牢的瞬間迄汛,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工骤视, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鞍爱,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓专酗,卻偏偏與公主長(zhǎng)得像睹逃,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子祷肯,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,773評(píng)論 6 342
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理沉填,服務(wù)發(fā)現(xiàn)疗隶,斷路器,智...
    卡卡羅2017閱讀 134,633評(píng)論 18 139
  • 在我搭建基于Spring Cloud的微服務(wù)體系應(yīng)用的時(shí)候所需要或者是常用的屬性配置文件翼闹,還有這些屬性的用途斑鼻,此配...
    StrongManAlone閱讀 3,997評(píng)論 0 18
  • 作者簡(jiǎn)介陳喆,現(xiàn)就職于中科院某研究所擔(dān)任副研究員橄碾,專注于工業(yè)云平臺(tái)卵沉、MES系統(tǒng)的設(shè)計(jì)與研發(fā)。 spring-mus...
    Gavin陳閱讀 840評(píng)論 0 1
  • 【玉淵潭的花】 今天的霧霾不算大 只有兩百八 絲毫不影響人們來(lái)看花 紅櫻海棠還有連翹 怒放盛開(kāi) 想掙扎樹(shù)枝的束縛 ...
    marquislove閱讀 283評(píng)論 0 1