欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解如何使用MyBatis實現(xiàn)數據庫的CRUD

 更新時間:2024年12月02日 08:32:08   作者:愛上語文  
這篇文章主要為大家詳細介紹了如何使用MyBatis實現(xiàn)數據庫的CRUD操作,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下

Mybatis中#占位符和$拼接符的區(qū)別

“#”占位符

在使用MyBatis操作數據庫的時候,可以直接使用如下代碼進行刪除數據

@Delete("delete from user where id=5")
public Integer deleteById();

這個代碼可以成功完成刪除user表中id為5的用戶,但是其實存在一個問題:硬編碼。把這個刪除的SQL語句寫死了,假如說下一次需要刪除id為6的用戶就又要重新編寫一條SQL了。所以說我們可以使用#占位符:

@Delete("delete from user where id=#{id}")
public Integer deleteById(Integer id);

這樣寫,需要給deleteById方法傳遞需要刪除的id,并使用#進行占位,在編譯時,就會將這條SQL語句編譯為一條預編譯SQL:delete from user where id=?。然后再用方法中的參數id去對預編譯SQL中的?進行參數綁定(將 Java 方法中的參數與 SQL 語句中的占位符建立關聯(lián)并賦值的動作),從而避免硬編碼的問題,并且還可以提高SQL語句的執(zhí)行效率(預編譯SQL提高SQL語句的執(zhí)行效率)。

“$”拼接符

和#占位符不同,$只是拼接符,是直接將參數值拼接在SQL中,并不能使SQL語句變成預編譯SQL,所以說還是存在SQL注入問題和性能低下的問題,所以說用的十分少。但是當表名和字段名需要動態(tài)變化的時候,就只能使用$拼接符,如:"select * from ${tablename}"這種動態(tài)的表名會使用$拼接符。

Create

create操作是在數據庫中新增一條數據,通過MyBatis中的@Insert注解可以便捷的完成數據的新增,當進行數據新增操作時,往往會涉及多個不同類型的屬性。從數據組織和管理的角度出發(fā),為了更好地維護數據的完整性和關聯(lián)性,通常會將這些相關屬性封裝為一個實體對象。這種實體對象的設計遵循面向對象編程的原則,以業(yè)務邏輯中的實際實體為藍本,例如在用戶管理系統(tǒng)中,用戶相關的屬性(如用戶名、密碼、姓名、年齡等)會被封裝在一個User實體對象中。這個實體對象會作為參數傳遞給負責新增數據的方法,SQL中的占位符會獲取對象中的屬性來拼接SQL:

@Insert("insert into user(id, username, password, name, age) " +
        "values (#{id}, #{username}, #{password}, #{name}, #{age})")
public Integer insertUser(User user);

values中的值就是User對象中的屬性,是#占位符從User對象中的屬性中獲取的。(如何獲取本文不過多贅述)

測試該方法:

@Test
public void testInsert() {
    User user = new User(null, "zhouyu", "123456", "周瑜", 23);
    Integer rows = userMapper.insertUser(user);
    System.out.println("影響的行數是:" + rows);
}

(因為id字段是主鍵,并且自增,所以說不需要傳遞id的參數。)

原數據表:

測試結果:

看到新增的方法成功在數據庫表中插入了一條新的數據,代表新增方法成功了。需要說明的是:id是自增的,前面自測的時候創(chuàng)建了很多user,所以說id自增到了10,雖然刪除了這些user,但是id也是從10開始自增的,所以說再次添加user,id從10自增,則變成11。

Read

Read操作是查詢(讀取)數據庫中的數據,通過MyBatis中的@Select注解可以便捷的完成數據的查詢:

@Select("select * from user where username = #{username} and password = #{password}")
public void selectUser(@Param("username")String username, @Param("password")String password);

此處只需要使用兩個字段進行查找,沒有必要將屬性封裝到User對象中,可以直接傳遞;但是需要非常注意的是此處傳遞的是參數名,#占位符綁定的也是參數名,但是在編譯后方法中的參數名不會保留,只會保留參數的類型,而#占位符參數綁定是在編譯后進行的,但是此時有兩個參數,#占位符無法進行準確綁定,所以說就會報錯。為了解決這個問題,需要在方法的參數之前添加@Param注解來指定該參數的名字,#占位符中也需要和@Param注解中相同的名字(參數名不重要),這樣才可以指定參數。但是假如是官方的SpringBoot框架,無需使用@Param注解,只要保證#占位符中的參數和方法的參數名相同即可,也可以完成綁定。

測試方法:

@Test
public void testFind() {
    User user = userMapper.selectUser("liubei", "123456");
    System.out.println(user);
}

發(fā)現(xiàn)根據username和password成功查詢到了User,說明查找方法成功。

Update

update操作是更新數據庫中的數據,通過MyBatis中的@Update注解可以便捷的完成數據的刪除:

@Update("update user set username=#{username}, password=#{password}, name=#{name}, age=#{age} where id=#{id}")
public Integer updateUser(User user);

和insert操作類似,需要將要更新的字段封裝為對應實體對象的屬性,然后通過#占位符獲取屬性,完成SQL語句的拼接,需要注意的是,在insert操作中,因為id是自增的,所以說不需要傳遞id屬性,但是在update操作中,很多時候都需要根據id屬性來找到要更新哪一條數據,所以說大多數時候是需要傳遞id的,但是也需要根據具體情況而定。

測試方法:

@Test
public void testUpdate() {
    User user = new User(1, "liubei", "123456", "劉備", 25);
    Integer rows = userMapper.updateUser(user);
    System.out.println("影響的行數是:" + rows);
}

測試前數據表:

測試結果:

發(fā)現(xiàn)id為1的用戶被修改為了劉備,說明該修改方法成功修改。

Delete

delete操作是刪除數據庫中的數據,通過MyBatis中的@Delete注解可以便捷的完成數據的刪除:

@Delete("delete from user where id=#{id}")
public Integer deleteById(Integer id);

在MyBatis中執(zhí)行所有的DML語句都是有返回值的,是int類型,代表這條語句影響的記錄數,通過測試方法來測試下這個刪除方法: 原數據表:

測試方法:

@Test
public void testDelete() {
    Integer rows = userMapper.deleteById(5);
    System.out.println("影響的行數是:" + rows);
}

我們看到#占位符確實將SQL變成了一條預編譯的SQL,并且這條SQL影響了一條記錄??纯磾祿熘械淖兓?/p>

id為5的記錄確實被刪除了,說明該方法測試成功。

以上就是詳解如何使用MyBatis實現(xiàn)數據庫的CRUD的詳細內容,更多關于MyBatis實現(xiàn)數據庫CRUD的資料請關注腳本之家其它相關文章!

相關文章

  • springboot設置了server.port但是沒有用,還是8080問題

    springboot設置了server.port但是沒有用,還是8080問題

    這篇文章主要介紹了springboot設置了server.port但是沒有用,還是8080問題的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • java枚舉類的屬性、方法和構造方法應用實戰(zhàn)

    java枚舉類的屬性、方法和構造方法應用實戰(zhàn)

    這篇文章主要介紹了java枚舉類的屬性、方法和構造方法應用,結合實例形式分析了java枚舉類的定義、構造及相關應用操作技巧,需要的朋友可以參考下
    2019-08-08
  • Java如何利用POI讀取Excel行數

    Java如何利用POI讀取Excel行數

    這篇文章主要介紹了java如何利用POI讀取Excel行數,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • IDEA實現(xiàn)遠程調試步驟詳解

    IDEA實現(xiàn)遠程調試步驟詳解

    這篇文章主要介紹了IDEA實現(xiàn)遠程調試步驟詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Java Spring boot 2.0 跨域問題的解決

    Java Spring boot 2.0 跨域問題的解決

    本篇文章主要介紹了Java Spring boot 2.0 跨域問題的解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Java網絡編程之簡單的服務端客戶端應用實例

    Java網絡編程之簡單的服務端客戶端應用實例

    這篇文章主要介紹了Java網絡編程之簡單的服務端客戶端應用,以實例形式較為詳細的分析了java網絡編程的原理與服務器端客戶端的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-04-04
  • Java 內部類的定義與范例

    Java 內部類的定義與范例

    說起內部類這個詞,想必很多人都不陌生,但是又會覺得不熟悉。原因是平時編寫代碼時可能用到的場景不多,用得最多的是在有事件監(jiān)聽的情況下,并且即使用到也很少去總結內部類的用法。今天我們就來一探究竟
    2021-11-11
  • Springboot Mybatis-Plus數據庫單元測試實戰(zhàn)(三種方式)

    Springboot Mybatis-Plus數據庫單元測試實戰(zhàn)(三種方式)

    這篇文章主要介紹了Springboot Mybatis-Plus數據庫單元測試實戰(zhàn)(三種方式),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Spring Boot配置接口WebMvcConfigurer的實現(xiàn)

    Spring Boot配置接口WebMvcConfigurer的實現(xiàn)

    這篇文章主要介紹了SpringBoot配置接口WebMvcConfigurer的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • Java8中List轉Map的多種方式代碼

    Java8中List轉Map的多種方式代碼

    這篇文章主要給大家介紹了關于Java8中List轉Map的多種方式,在實際項目中我們經常會用到List轉Map操作,本文介紹了多種方法的實現(xiàn)代碼,需要的朋友可以參考下
    2023-08-08

最新評論