1. 程式人生 > 其它 >Mybatis01-建立一個簡單的mybatis專案

Mybatis01-建立一個簡單的mybatis專案

1.新建專案

  1. 新建一個普通的maven專案
  2. 刪除src目錄(作為父工程)
  3. 匯入maven依賴
    <dependencies>
        <!--mysql驅動-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.27</version>
        </dependency>
        <!--mybatis-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.9</version>
        </dependency>
        <!--junit-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
        </dependency>
    </dependencies>

2.建立mybatis核心配置檔案

<?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.cj.jdbc.Driver"/><!--環境-->
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;serverTimezone=GMT"/>
                <property name="username" value="root"/>
                <property name="password" value="6113081"/>
            </dataSource>
        </environment>
    </environments>
    <!--對映mapper介面-->
    <mappers>
        <mapper resource="com/zhang/mapper/UserMapper.xml"></mapper>
    </mappers>
</configuration>

3.編寫一個mybatis工具類(類似於jducUtil工具類)

public class MybatisUtils {

    private static SqlSessionFactory sqlSessionFactory;
    /**
     * 每個基於 MyBatis 的應用都是以一個 SqlSessionFactory 的例項為核心的。
     * SqlSessionFactory 的例項可以通過 SqlSessionFactoryBuilder 獲得。
     * 而 SqlSessionFactoryBuilder 則可以從 XML 配置檔案或一個預先配置的 Configuration 例項來構建出 SqlSessionFactory 例項。
     */
    static {
        String resource = "mybatis-config.xml";
        try {
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }

    }
    /**
     * SqlSession 完全包含了面向資料庫執行sql命令所需的所有方法
     * @return
     */
    public static SqlSession getSqlSession() {
        return sqlSessionFactory.openSession();
    }
}

4.編寫mapper介面(原Dao層介面,提供方法)

public interface UserMapper {
    List<User> getUserList();
}

5.建立包含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">
<!--namespace綁定了一個對應的Dao/mapper介面-->
<!--此處的mapper配置相當於轉換了原先Dao中的介面實現類,相當於此xml檔案實現了Mapper介面中的方法-->
<mapper namespace="com.zhang.dao.UserDao">
    <!--select查詢方法,id表示為mapper介面的實現方法,resultType表示該方法返回型別-->
    <select id="getUserList" resultType="com.zhang.pojo.User"><!--返回結果集型別,可以單寫返回型別但不推薦-->
        select * from user ;
    </select>
</mapper>

6.對應的實體類建立(略)

7.編寫測試方法

public class UserDaoTest {
    @Test
    public void test(){
        //1.獲取sqlsession物件
        SqlSession sqlSession01 = MybatisUtils.getSqlSession();
        //2.方式一:getMapper(執行sql)
        UserDao mapper = sqlSession01.getMapper(UserDao.class);
        List<User> userList = mapper.getUserList();
        for (User user : userList) {
            System.out.println(user.toString());
        }
        sqlSession01.close();
        //3.方式二:(不推薦)
        SqlSession sqlSession02 = MybatisUtils.getSqlSession();
        List<User> users= sqlSession02.selectList("com.zhang.dao.UserDao.getUserList");
        for (User user : users) {
            System.out.println(user.toString());
        }
        sqlSession02.close();
    }
}

8.結果

User{id=1, name='zhangsan', pwd='123456'}
User{id=2, name='lisi', pwd='123456'}
User{id=3, name='wangwu', pwd='123456'}
User{id=1, name='zhangsan', pwd='123456'}
User{id=2, name='lisi', pwd='123456'}
User{id=3, name='wangwu', pwd='123456'}

9.總結

核心要素4點

  • 1.SqlSessionFactoryBuilder
    這個類可以被例項化、使用和丟棄,一旦建立了 SqlSessionFactory,就不再需要它了。 因此 SqlSessionFactoryBuilder 例項的最佳作用域是方法作用域(也就是區域性方法變數)。 你可以重用 SqlSessionFactoryBuilder 來建立多個 SqlSessionFactory 例項,但最好還是不要一直保留著它,以保證所有的 XML 解析資源可以被釋放給更重要的事情。

  • 2.SqlSessionFactory
    SqlSessionFactory 一旦被建立就應該在應用的執行期間一直存在,沒有任何理由丟棄它或重新建立另一個例項。 使用 SqlSessionFactory 的最佳實踐是在應用執行期間不要重複建立多次,多次重建 SqlSessionFactory 被視為一種程式碼“壞習慣”。因此 SqlSessionFactory 的最佳作用域是應用作用域。 有很多方法可以做到,最簡單的就是使用單例模式或者靜態單例模式。

  • 3.SqlSession
    每個執行緒都應該有它自己的 SqlSession 例項。SqlSession 的例項不是執行緒安全的,因此是不能被共享的,所以它的最佳的作用域是請求或方法作用域。 絕對不能將 SqlSession 例項的引用放在一個類的靜態域,甚至一個類的例項變數也不行。 也絕不能將 SqlSession 例項的引用放在任何型別的託管作用域中,比如 Servlet 框架中的 HttpSession。 如果你現在正在使用一種 Web 框架,考慮將 SqlSession 放在一個和 HTTP 請求相似的作用域中。 換句話說,每次收到 HTTP 請求,就可以開啟一個 SqlSession,返回一個響應後,就關閉它。 這個關閉操作很重要,為了確保每次都能執行關閉操作,你應該把這個關閉操作放到 finally 塊中。

  • 4.對映器例項
    對映器是一些繫結對映語句的介面。對映器介面的例項是從 SqlSession 中獲得的。雖然從技術層面上來講,任何對映器例項的最大作用域與請求它們的 SqlSession 相同。但方法作用域才是對映器例項的最合適的作用域。 也就是說,對映器例項應該在呼叫它們的方法中被獲取,使用完畢之後即可丟棄。 對映器例項並不需要被顯式地關閉。儘管在整個請求作用域保留對映器例項不會有什麼問題,但是你很快會發現,在這個作用域上管理太多像 SqlSession 的資源會讓你忙不過來。 因此,最好將對映器放在方法作用域內。