91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyBaits基本概念和原理

發布時間:2020-07-31 01:57:34 來源:網絡 閱讀:1008 作者:sun2shadows 欄目:軟件技術

什么是MyBatis?

MyBatis 是一款優秀的持久層框架,它支持定制化 SQL、存儲過程以及高級映射。MyBatis 避免了幾乎所有的 JDBC 代碼和手動設置參數以及獲取結果集。MyBatis 可以使用簡單的 XML 或注解來配置和映射原生信息,將接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java對象)映射成數據庫中的記錄。

MyBatis源碼對應的結構流程

MyBaits基本概念和原理

  1. SqlMapConfig.xml,此文件作為mybatis的全局配置文件,配置了mybatis的運行環境等信息。mapper.xml文件即sql映射文件,文件中配置了操作數據庫的sql語句,此文件需要在SqlMapConfig.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="development">  
        <environment id="development">  
            <transactionManager type="JDBC"/>    
            <dataSource type="POOLED">  
                <property name="driver" value="com.mysql.jdbc.Driver"/>  
                <property name="url" value="jdbc:mysql://localhost:3306/foretaste?zeroDateTimeBehavior=convertToNull "/>  
                <property name="username" value="root"/>  
                <property name="password" value="mysql123"/>  
            </dataSource>  
        </environment>  
    </environments>      
 
    <mappers>
        <mapper resource="mapper/UserInfoMapper.xml" />
    </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="com.shadow.foretaste.UserInfoDao">
    <select id="getUserInfoById" parameterType="int" resultType="com.shadow.foretaste.entity.UserInfo">
        select * from user_info where id = #{id}
    </select>
</mapper>

2.通過mybatis環境等配置信息構造SqlSessionFactory(即會話工廠)。

String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory =
  new SqlSessionFactoryBuilder().build(inputStream);

3.由會話工廠創建sqlSession即會話,操作數據庫需要通過sqlSession進行

SqlSession session = sqlSessionFactory.openSession();

4.mybatis底層自定義了Executor執行器接口操作數據庫,Executor接口有兩個實現,一個是基本執行器、一個是緩存執行器。

5.MappedStatement也是mybatis一個底層封裝對象,它包裝了mybatis配置信息及sql映射信息等。mapper.xml文件中一個sql對應一個MappedStatement對象,sql的id即是MappedStatement的id。

6.MappedStatement對sql執行輸入參數進行定義,包括HashMap、基本類型、pojo,Executor通過MappedStatement在執行sql前將輸入的java對象映射至sql中,輸入參數映射就是JDBC編程中對preparedStatement設置參數。

7.MappedStatement對sql執行輸出結果進行定義,包括HashMap、基本類型、pojo,Executor通過MappedStatement在執行sql后將輸出結果映射至java對象中,輸出結果映射過程相當于JDBC編程中對結果的解析處理過程。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

万源市| 社会| 铁岭县| 镇远县| 关岭| 康保县| 沙湾县| 蒙阴县| 肃南| 浦江县| 白河县| 晴隆县| 牡丹江市| 兴隆县| 邳州市| 涞水县| 大理市| 海晏县| 宜兰市| 鄂托克旗| 慈溪市| 株洲市| 长汀县| 滕州市| 仁化县| 大邑县| 丰县| 金沙县| 密云县| 辉南县| 竹北市| 庄浪县| 商丘市| 同江市| 军事| 兰西县| 罗平县| 杭锦后旗| 阳朔县| 手机| 河曲县|