Spring全家桶--單數(shù)據(jù)源的配置

前言

spring數(shù)據(jù)源的配置網(wǎng)絡(luò)上有很多例子禾酱,這里我也來(lái)介紹一下單數(shù)據(jù)源配置的例子,基于SpringBoot的方式和原生的Spring的方式。

一已骇、生成項(xiàng)目骨架(SpringBoot),運(yùn)行一個(gè)簡(jiǎn)單的程序

訪問:https://start.spring.io/ 票编,選擇必要的依賴

file

下面我們先看下Application類的代碼:

@SpringBootApplication
@Slf4j
public class SpringDatasourceApplication implements CommandLineRunner {

    @Autowired
    private DataSource dataSource;

    @Autowired
    private JdbcTemplate jdbcTemplate;

    public static void main(String[] args) {
        SpringApplication.run(SpringDatasourceApplication.class, args);
    }

    @Override
    public void run(String... args) throws Exception {
        showConnection();
        showData();
    }

    private void showConnection() throws SQLException {
        log.info("數(shù)據(jù)源:"+dataSource.toString());
        Connection conn = dataSource.getConnection();
        log.info("連接:"+conn.toString());
        conn.close();
    }

    private void showData() {
        jdbcTemplate.queryForList("SELECT * FROM user")
                .forEach(row -> log.info("記錄:"+row.toString()));
    }
}

application.properties文件的配置項(xiàng)褪储,我們可以看到我們使用的h2數(shù)據(jù)庫(kù)

management.endpoints.web.exposure.include=*
spring.output.ansi.enabled=ALWAYS

spring.datasource.url=jdbc:h2:mem:demodb
spring.datasource.username=sa
spring.datasource.password=

在資源文件目錄,寫入兩個(gè)文件慧域,一個(gè)是data.sql鲤竹、一個(gè)是schema.sql

file

schema.sql內(nèi)容是:

CREATE TABLE user (ID INT IDENTITY, name VARCHAR(64),age INT);

data.sql內(nèi)容是:

INSERT INTO user (ID,name,age) VALUES (1, '張三',18);
INSERT INTO user (ID, name,age) VALUES (2, '李四',19);

運(yùn)行代碼,結(jié)果如下:

file

其實(shí)我們并沒有去對(duì)DataSource進(jìn)行bean配置昔榴,只是指定了數(shù)據(jù)庫(kù)的類型辛藻,加載了建表語(yǔ)句和初始化數(shù)據(jù)語(yǔ)句,可以看到連接池是Hikari互订,這也是springboot默認(rèn)的連接池吱肌。
由于是使用的內(nèi)置數(shù)據(jù)庫(kù),我們可以在代碼中

這也是因?yàn)閟pringboot給我們自動(dòng)裝配了我們所需要的信息仰禽,由于我們引入了actuator氮墨,我們可以通過http://localhost:8080/actuator/beans 看到springboot幫我們裝載了很多的bean,有些可能是我們根本用不到的吐葵。下面我們講一下原生Spring方式怎么實(shí)現(xiàn)配置數(shù)據(jù)源规揪。

二、選擇原生Spring方式配置數(shù)據(jù)源

pom文件配置內(nèi)容:

  <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-dbcp2</artifactId>
            <version>2.8.0</version>
        </dependency>
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>1.4.200</version>
            <scope>runtime</scope>
        </dependency>
        ```
        
        **創(chuàng)建applicationContext.xml文件温峭,內(nèi)容如下:**  
```xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

    <context:component-scan base-package="com.xxx.xxxx" />
    <!--
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
          destroy-method="close">
        <property name="driverClassName" value="org.h2.Driver"/>
        <property name="url" value="jdbc:h2:mem:testdb"/>
        <property name="username" value="SA"/>
        <property name="password" value=""/>
    </bean>
    -->
</beans>

** 自定義DataSource粒褒,這里使用注解來(lái)實(shí)現(xiàn)(使用dbcp連接池) **

@Configuration
@EnableTransactionManagement
public class DataSourceDemo {
    @Autowired
    private DataSource dataSource;

    public static void main(String[] args) throws SQLException {
        ApplicationContext applicationContext =
                new ClassPathXmlApplicationContext("applicationContext*.xml");
        showBeans(applicationContext);
        dataSourceDemo(applicationContext);
    }

    @Bean(destroyMethod = "close")
    public DataSource dataSource() throws Exception {
        Properties properties = new Properties();
        properties.setProperty("driverClassName", "org.h2.Driver");
        properties.setProperty("url", "jdbc:h2:mem:testdb");
        properties.setProperty("username", "sa");
        return BasicDataSourceFactory.createDataSource(properties);
    }

    @Bean
    public PlatformTransactionManager transactionManager() throws Exception {
        return new DataSourceTransactionManager(dataSource());
    }

    private static void showBeans(ApplicationContext applicationContext) {
        System.out.println(Arrays.toString(applicationContext.getBeanDefinitionNames()));
    }

    private static void dataSourceDemo(ApplicationContext applicationContext) throws SQLException {
        DataSourceDemo demo = applicationContext.getBean("dataSourceDemo", DataSourceDemo.class);
        demo.showDataSource();
    }

    public void showDataSource() throws SQLException {
        System.out.println(dataSource.toString());
        Connection conn = dataSource.getConnection();
        System.out.println(conn.toString());
        conn.close();
    }
}

運(yùn)行main方法:


file

可以看到可以實(shí)現(xiàn)和springboot一樣的效果

通過上面的兩個(gè)例子,我們可以看出SpringBoot幫我們實(shí)現(xiàn)了如下功能:

  • 通過DataSourceAutoConfiguration 配置 DataSource
  • 通過DataSourceTransactionManagerAutoConfiguration 配置 DataSourceTransactionManager
  • 通過JdbcTemplateAutoConfiguration 配置 JdbcTemplate
    當(dāng)然上面是按需來(lái)配置的诚镰,如果我們?cè)诖a中已經(jīng)配置了一個(gè)DataSource奕坟,SpringBoot不會(huì)再幫我們配置一個(gè)DataSource

在實(shí)際情況下,我們可能需要在應(yīng)用中配置多個(gè)數(shù)據(jù)源清笨,下篇文章我將介紹多個(gè)數(shù)據(jù)源的配置方式月杉。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市抠艾,隨后出現(xiàn)的幾起案子苛萎,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件腌歉,死亡現(xiàn)場(chǎng)離奇詭異蛙酪,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)翘盖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門桂塞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人馍驯,你說我怎么就攤上這事阁危。” “怎么了汰瘫?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵狂打,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我混弥,道長(zhǎng)趴乡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任蝗拿,我火速辦了婚禮晾捏,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛹磺。我一直安慰自己,他們只是感情好同仆,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布萤捆。 她就那樣靜靜地躺著,像睡著了一般俗批。 火紅的嫁衣襯著肌膚如雪俗或。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天岁忘,我揣著相機(jī)與錄音辛慰,去河邊找鬼。 笑死干像,一個(gè)胖子當(dāng)著我的面吹牛帅腌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播麻汰,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼速客,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了五鲫?” 一聲冷哼從身側(cè)響起溺职,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后浪耘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體乱灵,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年七冲,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了痛倚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡癞埠,死狀恐怖状原,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情苗踪,我是刑警寧澤颠区,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站通铲,受9級(jí)特大地震影響毕莱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜颅夺,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一朋截、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧吧黄,春花似錦部服、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至赵抢,卻和暖如春剧蹂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背烦却。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工宠叼, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人其爵。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓冒冬,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親摩渺。 傳聞我的和親對(duì)象是個(gè)殘疾皇子窄驹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

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