MyBatis入門案例(一)

MyBatis入門案例(一)

需求

實現以下功能:
根據用戶id查詢一個用戶信息
根據用戶名稱模糊查詢用戶信息列表
添加用戶
更新用戶
刪除用戶

需求分析:

根據用戶id查詢一個用戶信息:
SELECT * FROM USER WHERE id=1

根據用戶名稱模糊查詢用戶信息列表:
SELECT * FROM USER WHERE username LIKE '%張%'

根據用戶id查詢一個用戶信息

  • SqlMapConfig.xml

    此方法爲mybatis的全局配置文件,配置了數據源、事務等運行環境,加載配置mapper.xml映射。

    使用mybatis-3-config.dtd約束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>

    <!-- 和spring整合後 environments配置將廢除 -->
    <environments default="development">
        <environment id="development">
            <!-- 使用jdbc事務管理 -->
            <transactionManager type="JDBC" />
            <!-- 數據庫連接池 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver" />
                <property name="url"
                    value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8" />
                <property name="username" value="root" />
                <property name="password" value="123" />
            </dataSource>
        </environment>
    </environments>

    <!-- 加載mapper.xml -->
    <!-- <mappers></mappers> -->


</configuration>
  • mapper.xml映射文件

    早期ibatis的映射文件以表名命名,後期mybatis 映射文件命名方式爲:表名Mapper.xml。。
    命名方式是不固定的。

    映射文件使用mybatis-3-mapper.dtd
    這裏寫圖片描述

    • pojo
      resultType:將sql查詢結果集映射成java對象
      將多個列的值映射到一個對象中,需要定義的pojo,resultType映射規則是sql查詢列名和pojo的屬性名必須一致方可完成映射。
      這裏寫圖片描述

    • mapper.xml
      這裏寫圖片描述

  • 在SqlMapConfig.xml加載映射文件
    編輯SqlMapConfig.xml,加載User.xml映射文件
    這裏寫圖片描述

代碼實現

@Test
    public void testFindUserById()throws Exception{

        //mybatis全局配置文件
        String resource = "SqlMapConfig.xml";

        //根據mybatis的全局配置文件構造 一個流
        InputStream inputStream = Resources.getResourceAsStream(resource);

        //創建SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //創建SqlSession會話

        SqlSession sqlSession = sqlSessionFactory.openSession();

        //使用sqlSession查詢用戶
        //第一個參數:statement的id,前邊要加namespace
        //第二個參數:輸入的參數對象值
        //selectOne用於返回單個對象,如果sql查詢返回一個列表(多個對象),如果使用selectOne報錯
        User user = sqlSession.selectOne("test.findUserById", 1);
        System.out.println(user);

        //關閉sqlsession
        sqlSession.close();

    }

調試控制檯結果顯示
這裏寫圖片描述

想看後續,請看 MyBatis入門案例(二)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章