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

前景概要

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

ORM的作用及Spring對數據庫的優化

現在我們都會看到網上流行各種ORM框架來操作數據庫,例如Mybatishibernate等,那到底為何要用ORM框架呢?
一開始的時候是沒有ORM存在的,那么使用JAVA操作數據庫步驟應該如下:

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

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();
    }
}

步驟詳解:

  • 加載數據庫驅動

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("create_time"));
}

  • 關閉連接

conn.close();

這種操作方式有幾個弊端:

  1. 需要自己管理數據庫連接(又要開啟又要關閉的,萬一沒關就泄露了,而且還沒有線程池,效率堪憂)
  2. 每次都要自己組裝SQL語句,很容易出錯
  3. 不是面向對象的方式,每次操作的時候都是要通過getString來獲取,需要對數據庫非常熟悉才行,也就是說耦合很深!

那么我們就來陸續解決這幾個問題:

問題解決及優化

解決數據庫連接管理問題

解決方式是引入數據庫連接池管理數據庫連接。

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

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

這個依賴中的 org.apache.commons.dbcp.BasicDataSource就是數據庫連接池的一個實現,可以有效管理數據庫連接,對這類數據庫連接資源我們稱之為數據源,在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();
}  

直接獲取數據庫連接,而不需要關心連接的關閉等問題!

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

對象映射

想象現在如果從數據庫取出的數據直接是一個對象!那多好!就不用重復寫rs.getString("uesrname")這種既需要知道類型、又需要知道字段名稱的重復語句,而是可以直接這樣寫Account.getUsername()
這樣簡直棒呆!
Mybatis正是為我們做了這樣一件事情。
08 Spring 操作持久層 這一章中,MybatisGenerator為我們做了如下的事情:

  • 創建數據表對應的對象(與數據表完全一樣)

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

      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語句

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

有這么好的利器,為何不用?
詳細使用請參考
08 Spring 操作持久層 (融合 Mybatis)最簡使用(使用 Mybatis Generator)

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評論 6 541
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,312評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 177,993評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,667評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,410評論 6 411
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,778評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,955評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,521評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,266評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,468評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,696評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,095評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,385評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,193評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,431評論 2 378

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,821評論 18 139
  • Spring Boot 參考指南 介紹 轉載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,914評論 6 342
  • 1. 簡介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存儲過程以及高級映射的優秀的...
    笨鳥慢飛閱讀 5,569評論 0 4
  • 今日《中國婦科醫生群》某醫生有一個病例在群里展開討論,如下: 某女因胚胎停育2次行染色體檢查,結果:女方為45,X...
    春花秋詩閱讀 747評論 0 2
  • 文/紫蘇子 文/紫蘇子 (一) 六月的最后幾天像是個大烤爐一樣,帶著炙熱的烈日肆意燒灼著大地的每...
    紫蘇子_閱讀 466評論 0 2