番外 02: Spring 之使用 JAVA 操作Mysql數(shù)據(jù)庫(kù)(為何要用ORM)Spring整合 Mybatis前基礎(chǔ)

前景概要

08 Spring 操作持久層 (融合 Mybatis)最簡(jiǎn)使用(使用 Mybatis Generator) 對(duì)外依賴過大界睁,對(duì)新手來說可能有跳躍性奴烙。
特寫此章做一下鋪墊米同。

ORM的作用及Spring對(duì)數(shù)據(jù)庫(kù)的優(yōu)化

現(xiàn)在我們都會(huì)看到網(wǎng)上流行各種ORM框架來操作數(shù)據(jù)庫(kù)端铛,例如Mybatishibernate等蚤告,那到底為何要用ORM框架呢练般?
一開始的時(shí)候是沒有ORM存在的矗漾,那么使用JAVA操作數(shù)據(jù)庫(kù)步驟應(yīng)該如下:

原始方式操作數(shù)據(jù)庫(kù)(直接獲取數(shù)據(jù)庫(kù)連接池)

App.java

package me.laiyijie.demo;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;

public class App {

    public static void main(String[] args) throws SQLException, ClassNotFoundException {

        Class.forName("com.mysql.jdbc.Driver");
        Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1/myspring", "test", "o34rWayJPPHgudtL");
        ResultSet rs = conn.createStatement().executeQuery("select * from account");

        while (rs.next()) {
            System.out.println("username: " + rs.getString("username") + " password: " + rs.getString("password") + " name: "
                    + rs.getString("name") + " create_time: " + rs.getLong("createtime"));
        }
        conn.close();
    }
}

步驟詳解:

  • 加載數(shù)據(jù)庫(kù)驅(qū)動(dòng)

Class.forName("com.mysql.jdbc.Driver");

  • 獲取數(shù)據(jù)庫(kù)連接

Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1/myspring", "test", "o34rWayJPPHgudtL");

  • 執(zhí)行查詢語(yǔ)句并獲取結(jié)果集

ResultSet rs = conn.createStatement().executeQuery("select * from account");

  • 輸出結(jié)果

while (rs.next()) {
System.out.println("username: " + rs.getString("username") + " password: " + rs.getString("password") + " name: " +
rs.getString("name") + " create_time: " + rs.getLong("create_time"));
}

  • 關(guān)閉連接

conn.close();

這種操作方式有幾個(gè)弊端:

  1. 需要自己管理數(shù)據(jù)庫(kù)連接(又要開啟又要關(guān)閉的,萬一沒關(guān)就泄露了薄料,而且還沒有線程池敞贡,效率堪憂)
  2. 每次都要自己組裝SQL語(yǔ)句,很容易出錯(cuò)
  3. 不是面向?qū)ο蟮姆绞缴阒埃看尾僮鞯臅r(shí)候都是要通過getString來獲取誊役,需要對(duì)數(shù)據(jù)庫(kù)非常熟悉才行,也就是說耦合很深琳钉!

那么我們就來陸續(xù)解決這幾個(gè)問題:

問題解決及優(yōu)化

解決數(shù)據(jù)庫(kù)連接管理問題

解決方式是引入數(shù)據(jù)庫(kù)連接池管理數(shù)據(jù)庫(kù)連接势木。

08 Spring 操作持久層 (融合 Mybatis)最簡(jiǎn)使用(使用 Mybatis Generator) 我們引入了:

<dependency>
    <groupId>commons-dbcp</groupId>
    <artifactId>commons-dbcp</artifactId>
    <version>1.4</version>
</dependency>

這個(gè)依賴中的 org.apache.commons.dbcp.BasicDataSource就是數(shù)據(jù)庫(kù)連接池的一個(gè)實(shí)現(xiàn),可以有效管理數(shù)據(jù)庫(kù)連接歌懒,對(duì)這類數(shù)據(jù)庫(kù)連接資源我們稱之為數(shù)據(jù)源啦桌,在Spring中的配置如下:

<bean id="mysqlDataSource" class="org.apache.commons.dbcp.BasicDataSource"
    p:driverClassName="com.mysql.jdbc.Driver"
    p:url="jdbc:mysql://127.0.0.1:3306/myspring"
    p:username="test" p:password="o34rWayJPPHgudtL" />  

也就是說,我們可以通過:

@Autowired
private BasicDataSource basicDataSource;

public void test() throws SQLException {
    Connection conn = basicDataSource.getConnection();
}  

直接獲取數(shù)據(jù)庫(kù)連接及皂,而不需要關(guān)心連接的關(guān)閉等問題甫男!

解決需要一直直接寫SQL和與對(duì)象映射問題(ORM出現(xiàn))

對(duì)象映射

想象現(xiàn)在如果從數(shù)據(jù)庫(kù)取出的數(shù)據(jù)直接是一個(gè)對(duì)象!那多好验烧!就不用重復(fù)寫rs.getString("uesrname")這種既需要知道類型板驳、又需要知道字段名稱的重復(fù)語(yǔ)句,而是可以直接這樣寫Account.getUsername()碍拆。
這樣簡(jiǎn)直棒呆若治!
Mybatis正是為我們做了這樣一件事情慨蓝。
08 Spring 操作持久層 這一章中,MybatisGenerator為我們做了如下的事情:

  • 創(chuàng)建數(shù)據(jù)表對(duì)應(yīng)的對(duì)象(與數(shù)據(jù)表完全一樣)

      public class Account {
          private String username;
      
          private String password;
      
          private String name;
      
          private Long create_time;
          
      }   
    
  • 查詢后將結(jié)果與對(duì)象映射(也就是查詢完成直接返回對(duì)象)

      public interface AccountMapper {
          long countByExample(AccountExample example);
      
          int deleteByExample(AccountExample example);
      
          int deleteByPrimaryKey(String username);
      
          int insert(Account record);
      
          int insertSelective(Account record);
      
          List<Account> selectByExample(AccountExample example);
      
          Account selectByPrimaryKey(String username);
      
          int updateByExampleSelective(@Param("record") Account record, @Param("example") AccountExample example);
      
          int updateByExample(@Param("record") Account record, @Param("example") AccountExample example);
      
          int updateByPrimaryKeySelective(Account record);
      
          int updateByPrimaryKey(Account record);
      }   
    
  • 不用直接組裝SQL語(yǔ)句

      public List<Account> getAccountsByCreateTime(Long start, Long end) {
          AccountExample accountExample = new AccountExample();
          accountExample.or().andCreate_timeGreaterThan(start).andCreate_timeLessThanOrEqualTo(end);
          return accountMapper.selectByExample(accountExample);
      }   
    

有這么好的利器端幼,為何不用礼烈?
詳細(xì)使用請(qǐng)參考
08 Spring 操作持久層 (融合 Mybatis)最簡(jiǎn)使用(使用 Mybatis Generator)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市婆跑,隨后出現(xiàn)的幾起案子此熬,更是在濱河造成了極大的恐慌,老刑警劉巖滑进,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件犀忱,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡扶关,警方通過查閱死者的電腦和手機(jī)阴汇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來节槐,“玉大人鲫寄,你說我怎么就攤上這事》枰” “怎么了?”我有些...
    開封第一講書人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵戳玫,是天一觀的道長(zhǎng)熙掺。 經(jīng)常有香客問我,道長(zhǎng)咕宿,這世上最難降的妖魔是什么币绩? 我笑而不...
    開封第一講書人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮府阀,結(jié)果婚禮上缆镣,老公的妹妹穿的比我還像新娘。我一直安慰自己试浙,他們只是感情好董瞻,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著田巴,像睡著了一般钠糊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上壹哺,一...
    開封第一講書人閱讀 49,046評(píng)論 1 285
  • 那天抄伍,我揣著相機(jī)與錄音,去河邊找鬼管宵。 笑死截珍,一個(gè)胖子當(dāng)著我的面吹牛攀甚,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播岗喉,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼秋度,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了沈堡?” 一聲冷哼從身側(cè)響起静陈,我...
    開封第一講書人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎诞丽,沒想到半個(gè)月后鲸拥,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡僧免,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年刑赶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片懂衩。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡撞叨,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出浊洞,到底是詐尸還是另有隱情牵敷,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布法希,位于F島的核電站枷餐,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏苫亦。R本人自食惡果不足惜毛肋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望屋剑。 院中可真熱鬧润匙,春花似錦、人聲如沸唉匾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)巍膘。三九已至卫病,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間典徘,已是汗流浹背蟀苛。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逮诲,地道東北人帜平。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓幽告,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親裆甩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子冗锁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)嗤栓,斷路器冻河,智...
    卡卡羅2017閱讀 134,599評(píng)論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,748評(píng)論 6 342
  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL茉帅、存儲(chǔ)過程以及高級(jí)映射的優(yōu)秀的...
    笨鳥慢飛閱讀 5,429評(píng)論 0 4
  • 今日《中國(guó)婦科醫(yī)生群》某醫(yī)生有一個(gè)病例在群里展開討論叨叙,如下: 某女因胚胎停育2次行染色體檢查,結(jié)果:女方為45堪澎,X...
    春花秋詩(shī)閱讀 728評(píng)論 0 2
  • 文/紫蘇子 文/紫蘇子 (一) 六月的最后幾天像是個(gè)大烤爐一樣樱蛤,帶著炙熱的烈日肆意燒灼著大地的每...
    紫蘇子_閱讀 448評(píng)論 0 2