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

使用Mybatis對數(shù)據(jù)庫進行單表操作的實現(xiàn)示例

 更新時間:2020年08月08日 09:31:42   作者:cing_self  
這篇文章主要介紹了使用Mybatis對數(shù)據(jù)庫進行單表操作的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

簡介

該篇文章主要是介紹如何使用MyBatis對Mysql數(shù)據(jù)庫進行單表操作(對于mybatis的下載以及配置文件的作用和具體信息,我在上一篇文章中也已經(jīng)提到了),使用的環(huán)境如下:

  • JDK版本:1.8
  • 編譯器:IDEA2019
  • JDBC版本:8.0.18
  • mybatis版本:3.5.3

配置文件

首先需要有兩個配置文件,一個是configuration.xml文件,配置的是連接數(shù)據(jù)庫的環(huán)境以及對于mapper.xml文件的映射,還有另一個文件就是mapper.xml,這個文件主要是用來寫sql語句的

configuration.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
    PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
  <environments default="e1">
    <environment id="e1">
      <transactionManager type="JDBC"></transactionManager>
      <dataSource type="POOLED">
        <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/bank?serverTimezone=CST"/>
        <property name="username" value="root"/>
        <property name="password" value="123456"/>
      </dataSource>
    </environment>
    <environment id="e2">
      <transactionManager type=""></transactionManager>
      <dataSource type=""></dataSource>
    </environment>
  </environments>
  <mappers>
    <mapper resource="mapper/UserMapper.xml"></mapper>
  </mappers>
</configuration>

mapper.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="dao.UserDao">
  <insert id="insert">
    INSERT ATM VALUES(#{account}, #{password}, #{balance})
  </insert>
  <update id="update">
    update atm set account=#{account},password=#{password},balance=#{balance} where account=#{account};
  </update>
  <delete id="delete">
    DELETE FROM ATM WHERE account=#{account};
  </delete>

  <select id="selectAll" resultType="domain.User">
    SELECT *FROM atm;
  </select>

  <select id="getTotalCount" resultType="integer">
    SELECT COUNT(*) FROM atm;
  </select>
  <select id="gettotal" resultType="hashmap">
    select count(*),max(balance) from atm;
  </select>


  <select id="selectAllByAcc" resultType="domain.User">
    SELECT *FROM atm order by ${flag} ${order};
  </select>
</mapper>

具體操作

具體操作看如下代碼,我對代碼都進行了一定的注釋,并結(jié)合mapper.xml文件一起看

public class UserDao {

  //增加一條記錄,user對象是我創(chuàng)建的實體類
    //mapper.xml文件的sql語句如下:
    //update atm set account=#{account},password=#{password},balance=#{balance} where account=#{account};
    //#{key}中的key要和實體類user的屬性名一致
    //如果傳遞的是基本數(shù)據(jù)類型或者String,且#{key}只有一個,那么名字可以不一致
    //如果傳入的是map集合,#{key}中的key要和map集合里的key一致
  public void insert(User user){
    //MYBATIS操作流程
    //獲取工廠Builder對象
    SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
    //獲取configuration.xml配置文件的輸入流
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    //builder根據(jù)is獲取SqlSessionFactory工廠對象
    SqlSessionFactory factory = builder.build(is);
    //獲取SqlSession對象
    SqlSession sqlSession = factory.openSession();
    //執(zhí)行sql語句操作
      //insert是在mapper.xml下,insert標簽的id名
      //user是我要插入的數(shù)據(jù)(動態(tài)操作),替換掉sql語句的#{}
    sqlSession.insert("insert", user);

    sqlSession.commit();
  }

  //改:修改記錄,user是要修改的數(shù)據(jù)
    //mapper.xml文件的sql語句如下:
    //update atm set account=#{account},password=#{password},balance=#{balance} where account=#{account};
  public void update(User user){
    //MYBATIS操作流程
    //獲取工廠Builder對象
    SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
    //獲取configuration.xml配置文件的輸入流
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    //builder根據(jù)is獲取SqlSessionFactory工廠對象
    SqlSessionFactory factory = builder.build(is);
    //獲取SqlSession對象
    SqlSession sqlSession = factory.openSession(true);
    //執(zhí)行sql語句操作
    sqlSession.update("update",user);
  }
  
  //刪除:根據(jù)account刪除
  //mapper.xml的sql語句如下:
    // DELETE FROM ATM WHERE account=#{account};
  public void delete(String account){
    //MYBATIS操作流程
    //獲取工廠Builder對象
    SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
    //獲取configuration.xml配置文件的輸入流
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    //builder根據(jù)is獲取SqlSessionFactory工廠對象
    SqlSessionFactory factory = builder.build(is);
    //獲取SqlSession對象
    SqlSession sqlSession = factory.openSession(true);
    //執(zhí)行sql語句操作
    sqlSession.update("delete",account);
  }
  
  
  //===============================查詢====================================
  //查詢:查找記錄總條數(shù)以及balance的最大值
  //sql語句如下:select count(*),max(balance) from atm;
  //select標簽上的resultType表示的是返回值,指的是一條記錄的類型,最后包裹成list集合
    //我這里用的hashMap
  public List<Map<String, Object>> gettotal(){
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
    SqlSession sqlSession = factory.openSession(true);
    return sqlSession.selectList("gettotal");
  }
  
  //查詢:獲取總記錄數(shù)
  //sql語句: SELECT COUNT(*) FROM atm;
  //resultType類型:integer
  public Integer getTotalCount(){
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
    SqlSession sqlSession = factory.openSession(true);
    return sqlSession.selectOne("getTotalCount");
  }
  
  //查詢:獲取表格的所有記錄
  //sql語句:SELECT *FROM atm;
  //resultType類型:domain.User (如果是自己寫的實體類,需要類名的具體路徑,除非做了配置)
  public List<User> selectAll(){
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
    SqlSession sqlSession = factory.openSession(true);
    return sqlSession.selectList("selectAll");
  }

  //查詢:查詢所有該表所有記錄,并根據(jù)flag列進行order排序
      //flag不確定,order可能是升序也可能是降序(由調(diào)用這個方法的用戶決定)
  //sql語句: SELECT *FROM atm order by ${flag} ${order};
    //這里用的是${}而不是#{}
    //#{}和${}的區(qū)別:
    //#{}:當我們的動態(tài)參數(shù)是用作條件的時候我們用這個,比如說account=#{key}
    //${}:當我們的動態(tài)參數(shù)表示的是一個普通字符串,比如說表名、列名或者關(guān)鍵字我們用這個
  //resultType:domain.User(domain包下的User類)
  public List<User> selectAllByAcc(String flag, String order){
    InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("configuration.xml");
    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);
    SqlSession sqlSession = factory.openSession(true);
    Map<String, Object> map = new HashMap<>();
    map.put("flag", flag);
    map.put("order", order);
    return sqlSession.selectList("selectAllByAcc", map);
  }
}

關(guān)于單表操作的底層原理

這里我簡單提一下關(guān)于增刪改查操作的底層原理,以查詢操作為例,查詢操作和增刪改操作的主要區(qū)別在于sql語句的不同以及查詢操作有返回值,所以底層還需要處理返回值

例如:sqlSession.selectOne(sql,obj)

1)首先,底層需要根據(jù)configuration.xml,找到mysql的驅(qū)動類driver,加載驅(qū)動
2)根據(jù)configuration.xml文件,找到連接MySQL數(shù)據(jù)庫的url,user,password,獲取連接Connection
3)參考configuration.xml配置文件,找到mapper.xml文件,從而找到sql語句,創(chuàng)建狀態(tài)參數(shù)PreparedStatement
4)解析sql語句,把#{key}或者${key}轉(zhuǎn)換成?的形式,并記錄key的名字,根據(jù)傳遞過來的obj匹配key,如果傳遞過來的是domain實體對象,通過反射獲取domain實體中的所有屬性,根據(jù)屬性名字去匹配key,然后調(diào)用狀態(tài)參數(shù)的setObject方法對?進行復制(其他類型的對象也基本如此)
5)執(zhí)行SQL操作,獲取結(jié)果集
6)分析ResultType屬性,獲取返回值類型,通過反射創(chuàng)建對象,遍歷結(jié)果集,將結(jié)果集包裝成返回值類型的對象
基本的流程大概就是這樣,本篇文章主要是對單表操作進行介紹,下一篇文章會介紹如果是多表,該如何進行操作

到此這篇關(guān)于使用Mybatis對數(shù)據(jù)庫進行單表操作的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)Mybatis 數(shù)據(jù)庫單表操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • JAVA讀取文本文件內(nèi)容實例代碼

    JAVA讀取文本文件內(nèi)容實例代碼

    這篇文章主要給大家介紹了關(guān)于JAVA讀取文本文件內(nèi)容的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Java具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-09-09
  • RocketMQ事務消息機制詳解

    RocketMQ事務消息機制詳解

    這篇文章主要介紹了RocketMQ事務消息機制詳解,RocketMQ服務端將消息持久化之后,向發(fā)送方返回Ack確認消息已經(jīng)發(fā)送成功,由于消息為半事務消息,在未收到生產(chǎn)者對該消息的二次確認前,此消息被標記成"暫不能投遞"狀態(tài),需要的朋友可以參考下
    2024-01-01
  • 從零實現(xiàn)一個簡單的Spring Bean容器的代碼案例

    從零實現(xiàn)一個簡單的Spring Bean容器的代碼案例

    Spring是一個非常流行的Java?Web開發(fā)框架,它提供了強大的依賴注入、面向切面編程、聲明式事務管理等功能,為開發(fā)者提供了高效、快速地構(gòu)建Web應用程序的工具,在這篇文章中,咱們將一步一步地構(gòu)建一個簡單的SpringBean容器,需要的朋友可以參考下
    2023-06-06
  • 深入講解Java的對象頭與對象組成

    深入講解Java的對象頭與對象組成

    由于Java面向?qū)ο蟮乃枷?在JVM中需要大量存儲對象,存儲時為了實現(xiàn)一些額外的功能,需要在對象中添加一些標記字段用于增強對象功能,這些標記字段組成了對象頭,下面這篇文章主要給大家介紹了關(guān)于Java對象頭與對象組成的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • Java語言實現(xiàn)簡單FTP軟件 FTP連接管理模塊實現(xiàn)(8)

    Java語言實現(xiàn)簡單FTP軟件 FTP連接管理模塊實現(xiàn)(8)

    這篇文章主要為大家詳細介紹了Java語言實現(xiàn)簡單FTP軟件,F(xiàn)TP連接管理模塊的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • Java中日期格式化YYYY-DD的操作bug

    Java中日期格式化YYYY-DD的操作bug

    這篇文章主要介紹了Java中日期格式化YYYY-DD中遇到的坑,本文給大家分享到腳本之家平臺,需要的朋友可以參考下
    2020-01-01
  • 關(guān)于Java中static關(guān)鍵字的用法

    關(guān)于Java中static關(guān)鍵字的用法

    這篇文章主要介紹了關(guān)于Java中static關(guān)鍵字的用法,static:意為靜態(tài)的,在?Java?里面作為靜態(tài)修飾符,可以理解為全局的意思,static?不僅可以修飾成員變量,成員方法,還可以修飾代碼塊,需要的朋友可以參考下
    2023-08-08
  • ZooKeeper命令及JavaAPI操作代碼

    ZooKeeper命令及JavaAPI操作代碼

    ZooKeeper是一個樹形目錄服務,其數(shù)據(jù)模型和Uiix的文件目錄樹很類似,擁有一個層次化結(jié)構(gòu),這篇文章主要介紹了ZooKeeper命令及JavaAPI操作代碼,需要的朋友可以參考下
    2023-03-03
  • Java調(diào)用Python腳本傳遞數(shù)據(jù)并返回計算結(jié)果

    Java調(diào)用Python腳本傳遞數(shù)據(jù)并返回計算結(jié)果

    實際工程項目中可能會用到Java和python兩種語言結(jié)合進行,這樣就會涉及到一個問題,Java如何調(diào)用Python腳本,感興趣的可以了解一下
    2021-05-05
  • SpringSecurity 手機號登錄功能實現(xiàn)

    SpringSecurity 手機號登錄功能實現(xiàn)

    這篇文章主要介紹了SpringSecurity 手機號登錄功能實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2023-12-12

最新評論