您現在的位置是:網站首頁>PythonMybatis如何通過接口實現sql執行原理解析

Mybatis如何通過接口實現sql執行原理解析

宸宸2024-02-22Python128人已圍觀

爲網友們分享了相關的編程文章,網友饒鵬鶤根據主題投稿了本篇教程內容,涉及到mybatis、sql執行、mybatis接口、Mybatis接口實現sql執行相關內容,已被262網友關注,內容中涉及的知識點可以在下方直接下載獲取。

Mybatis接口實現sql執行

使用過 mybatis 框架的小夥伴們都知道,mybatis 是個半 orm 框架,通過寫 mapper 接口就能自動實現數據庫的增刪改查,但是對其中的原理一知半解,接下來就讓我們深入框架的底層一探究竟

1、環境搭建

首先引入 mybatis 的依賴,在 resources 目錄下創建 mybatis 核心配置文件 mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <!-- 環境、事務工廠、數據源 -->
    <environments default="dev">
        <environment id="dev">
            <transactionManager type="JDBC"/>
            <dataSource type="UNPOOLED">
                <property name="driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
                <property name="url" value="jdbc:derby:db-user;create=true"/>
            </dataSource>
        </environment>
    </environments>

    <!-- 指定 mapper 接口-->
    <mappers>
        <mapper class="com.myboy.demo.mapper.user.UserMapper"/>
    </mappers>

</configuration>

在 com.myboy.demo.mapper.user 包下新建一個接口 UserMapper

public interface UserMapper {
    UserEntity getById(Long id);
    void insertOne(@Param("id") Long id, @Param("name") String name, @Param("json") List<String> json);
}

在 resources 的 com.myboy.demo.mapper.user 包下創建 UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.myboy.demo.mapper.user.UserMapper">

    <select id="getById" resultType="com.myboy.demo.db.entity.UserEntity">
        select * from demo_user where id = #{id}
    </select>

    <insert id="insertOne">
        insert into demo_user (id, name, json) values (#{id}, #{name}, #{json})
    </insert>
</mapper>

創建 main 方法測試

try(InputStream in = Resources.getResourceAsStream("com/myboy/demo/sqlsession/mybatis-config.xml")){
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
    sqlSession = sqlSessionFactory.openSession();
    # 拿到代理類對象
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    # 執行方法
    UserEntity userEntity = mapper.getById(2L);
    System.out.println(userEntity);
    sqlSession.close();
}catch (Exception e){
    e.printStackTrace();
}

2、動態代理類的生成

我的名片

網名:星辰

職業:程式師

現居:河北省-衡水市

Email:[email protected]