mybatis入“坑”第一步


一、導入坐標

要想通過maven創建一個簡單的mybatis項目,首先需要的是要導入相關的坐標。需要導入的坐標如下:

<dependencies>
	<!--mysql驅動坐標-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.46</version>
    </dependency>
    <!-- mybatis坐標 -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.6</version>
    </dependency>
    <!--單元測試坐標-->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
</dependencies>

創建實體類User和在數據庫中插入創建對應的user表。

二、配置mybatis的核心配置文件mybtis-config.xml

創建mybatis-config.xml的配置文件,用於配置連接數據庫和注冊Mapper.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>
    <properties resource="db.properties" />

    <!--數據庫連接的環境配置-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>

    <!--每一個Mapper.xml都需要在mybatis核心配置文件中注冊-->
    <mappers>
        <mapper resource="com/wkx/dao/UserMapper.xml"/>
    </mappers>
</configuration>

①properties標簽:可以動態配置屬性。

可以全部在外部進行配置,如下:

<properties resource="db.properties" />

也可以在通過property標簽一部分在外部進行內部配置另一部分在內部進行配置(如下),增加配置的靈活性。

<properties resource="db.properties">
    <property name="username" value="root"/>
    <property name="password" value="123456"/>
</properties>

②環境配置environments標簽:用於配置數據的環境。可配置多個數據庫環境,但是SqlSessionFactory只能選擇一個去使用。如下:

<environments default="development">
    <environment id="development">
        <transactionManager type="JDBC"/>
        <dataSource type="POOLED">
            <property name="driver" value="${driver}"/>
            <property name="url" value="${url}"/>
            <property name="username" value="${username}"/>
            <property name="password" value="${password}"/>
        </dataSource>
    </environment>
    <environment id="test">
        <transactionManager type="JDBC"/>
        <dataSource type="POOLED">
            <property name="driver" value="${driver}"/>
            <property name="url" value="${url}"/>
            <property name="username" value="${username}"/>
            <property name="password" value="${password}"/>
        </dataSource>
    </environment>
</environments>

可以在不同的環境下切換不同的數據環境,只需要修改environments標簽中的default屬性對應不同環境下的id屬性,比如development和test不同的環境。

③映射器mappers:定義映射的路徑,告訴mybatis去哪里找對應的語句。除了上述通過類路徑的資源引用方式,也可以通過其它的方式。比如通過包的形式將映射器接口全部注冊為映射器,如下:

<mappers>
  <package name="com.wkx.dao"/>
</mappers>

問題:Mapper.xml的配置文件在mybatis核心配置文件注冊時找不到對應Mapper.xml,是因為maven讀取配置文件時只在resources的文件目錄下尋找,所以需要在pom.xml文件中配置過濾器。所以pom.xml中應該添加如下代碼:

<!--在build中配置resources,來防止資源導出失敗的原因-->
<build>
    <resources>
        <resource>
            <directory>src/main/resources</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
            </includes>
            <filtering>true</filtering>
        </resource>

        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
            </includes>
            <filtering>true</filtering>
        </resource>
    </resources>
</build>

三、創建Mapper.xml

完成mybatis-config.xml配置文件的創建后,接着需要配置相關的Mapper.xml,進而進行SQL語句的編寫。

<mapper namespace="com.wkx.dao.UserMapper">
    <select id="getUser" resultType="com.wkx.pojo.User">
        select * from user
    </select>

    <!--使用User類作為輸入類型-->
    <update id="updateUser" parameterType="com.wkx.pojo.User">
        update user set name=#{name},pwd=#{pwd} where id=#{id}
    </update>

    <!--map類型(只需要其中的key對應sql語句中的需要注入的值)-->
    <update id="updateUserMap" parameterType="map">
        update user set name=#{username} where id=#{uid}
    </update>
</mapper>

①namespace命名空間:使用全限定類名對語句進行隔離,以及實現對接口的綁定。

②select、update等標簽中的id屬性對應的是Mapper接口中的方法名。通過id找到對應的方法需要執行的SQL語句。

③使用的Map集合類型對數據的SQL語句進行操作,只需要將Map集合中key對應SQL語句中的需要注入的值。也就是說SQL注入的值可以不和實體類中屬性一致。同時,使用Map集合而不是User類作為傳入類型進行傳輸時不需要將User類中所有數據傳輸。

四、編寫工具類

mybatis的使用需要以SqlSessionFactory為核心,使用SqlSessionFactory去生產SqlSession對象。創建一個工具類去生產SqlSession對象,以后使用mybatis便可以從該工具類中拿出SqlSession。

public class MybatisUtils {

    private static SqlSessionFactory sqlSessionFactory;

    // 調用該類執行該靜態模塊中的代碼,獲取SqlSessionFactory
    static {
        try {
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    // 通過該方法可以生產SqlSession對象
    public SqlSession getSqlSession(){
        SqlSession sqlSession = sqlSessionFactory.openSession();
        return sqlSession;
    }
}

五、測試

接着我們就可以利用mybatisUtils工具類生產的SqlSession對象去調用openSession執行對應的Mapper接口,就可以調用接口中的方法去執行對應的SQL語句。

具體測試類如下:

// 查詢所有用戶信息
@Test
public void queryUserTest(){
    MybatisUtils mybatisUtils = new MybatisUtils();
    // 調用mybatisUtils中的getSqlSession方法獲取SqlSession對象
    SqlSession sqlSession = mybatisUtils.getSqlSession();
    // 執行SqlSession中的getMapper方法,以便后來來執行對應的Mapper接口方法
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);

    // 執行接口方法,配置完成mybatis會調用的對應的SQL語句執行
    List<User> user = mapper.getUser();
    sqlSession.close();
    System.out.println(user);
}
// 使用Map數據類型對數據進行更新
@Test
public void updateUserMap(){
    MybatisUtils mybatisUtils = new MybatisUtils();
    SqlSession sqlSession = mybatisUtils.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);

    Map<String,Object> map = new HashMap<>();

    map.put("username","王三");
    // map.put("password","2334op");
    map.put("uid","3");

    int count = mapper.updateUserMap(map);

    /*增刪改的數據庫操作需要提交事務*/
    sqlSession.commit();
    sqlSession.close();
    System.out.println(count);
}

注意:① 增刪改的SQL語句操作都需要進行事務的提交。
         ② SqlSession使用完后要記得關閉。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM