1. 程式人生 > >MyBatis入門

MyBatis入門

jdbc 沒有 scope input logs 結果 implement settings log4j

MyBatis的基本構成

  • SqlSessionFactoryBuilder(構造器):它會根據配置信息或者代碼來生成SqlSessionFactory(工廠接口)
  • SqlSessionFactory:依靠工廠來生成會話SqlSession
  • SqlSession 是一個既可以發送Sql去執並返回結果,也可以獲取Mapper接口
  • SQLMapper MyBatis的新設計組件,它是由一個java接口和xml文件(或者註解)構成,需要給出對應的Sql和映射規則,他負責發送sql去執行,並返回結果.

Mybatis構成如下圖:

技術分享

構建SqlSessionFactory

SqlSessionFactory實例可以通過SqlSessionFactoryBuilder獲得,SqlSessionFactory是一工廠接口而不是一個實現類,構建SqlSessionFactory有兩種方式,

一種是基於xml文件,另一種是直接通過代碼實現,一般情況下使用xml配置文件的情況較多,一方面避免硬編碼,一方面方便易於維護。這裏我們介紹用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>
    <!--  
    <settings>
        <setting name ="logImpl" value ="LOG4J"/>
    </settings>
    
--> <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/mybatis" /> <property name="username" value="root" /> <property name="password" value="1234" /> </dataSource> </environment> </environments> <!-- 加載持久化對象 --> <mappers> <mapper resource="com/lg/mapper/UserMapper.xml"/> </mappers> </configuration>

實現創建SqlSessionFactory

//讀取mybatis配置文件
        InputStream inputStream=Resources.getResourceAsStream("mybatis-config.xml");
        System.out.println("ok");
        //初始化mybatis
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

創建SqlSession

Sqlsession是一個是一類接口類,它的功能是將參數或者信息傳遞給其他地方處理,其實現類有兩個,一個是DefaultSqlSession和SqlSessionManager.

//創建sqlSession實例
        SqlSession sqlsession=null;
        try{
            sqlsession=sessionFactory.openSession();
            //提交事務
            sqlsession.commit();
        }catch(Exception e){
            System.out.println(e);
            sqlsession.rollback();
        }finally{
            //關閉session
            sqlsession.close();
        }

SqlSeesion的作用主要有兩種:

  • 獲取映射器,讓映射器通過命名空間和方法找到對應的sql,發送給數據庫執行後放回結果
  • 直接通過命名信息區執行sql返回結果

映射器

映射器主要由java接口和xml文件組成,它有這些作用:

  1. 定義參數類型
  2. 描述緩存
  3. 描述sql語句
  4. 定義查詢結果和POJO的映射關系

下面介紹一下用xml實現Mapper

首先給出java接口

public interface UserMapper {
    
    public User getUser(int uid);
}

給出一個userMapper的xml映射文件,並在mybatis-config.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.lg.mapper.UserMapper">
    <insert id = "save" parameterType= "com.lg.model.User" useGeneratedKeys= "true">
        INSERT INTO user (username,password,image) VALUES(#{username},#{password},#{image})
    </insert>
    <select id="getUser" parameterType="int" 
        resultType="com.lg.model.User">
        select * from user where uid = #{uid}
    </select>
</mapper>

建立POJO

技術分享
package com.lg.model;

import java.io.Serializable;
public class User implements Serializable {
    /**
     * 
     */
    private static final long serialVersionUID = 4025045945853137268L;
    private String username;
    private String password;
    private String image;
    
    public User(){
        
    }
    
    
    
    public User(String username, String password, String image) {
        super();
        this.username = username;
        this.password = password;
        this.image = image;
    }



    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    public String getImage() {
        return image;
    }
    public void setImage(String image) {
        this.image = image;
    }
    
}
View Code

使用SqlSession獲取Mapper

        UserMapper userMapper= sqlsession.getMapper(UserMapper.class);
            User user = userMapper.getUser(1);
            System.out.println(user.getUsername());

生命周期

SqlSessionFactoryBuilder

這個類可以被實例化、使用和丟棄,一旦創建了 SqlSessionFactory,就不再需要它了。因此 SqlSessionFactoryBuilder 實例的最佳作用域是方法作用域(也就是局部方法變量)。你可以重用 SqlSessionFactoryBuilder 來創建多個 SqlSessionFactory 實例,但是最好還是不要讓其一直存在以保證所有的 XML 解析資源開放給更重要的事情。

SqlSessionFactory

SqlSessionFactory 一旦被創建就應該在應用的運行期間一直存在,沒有任何理由對它進行清除或重建。使用 SqlSessionFactory 的最佳實踐是在應用運行期間不要重復創建多次,多次重建 SqlSessionFactory 被視為一種代碼“壞味道(bad smell)”。因此 SqlSessionFactory 的最佳作用域是應用作用域。有很多方法可以做到,最簡單的就是使用單例模式或者靜態單例模式。

SqlSession

每個線程都應該有它自己的 SqlSession 實例。SqlSession 的實例不是線程安全的,因此是不能被共享的,所以它的最佳的作用域是請求或方法作用域。絕對不能將 SqlSession 實例的引用放在一個類的靜態域,甚至一個類的實例變量也不行。也絕不能將 SqlSession 實例的引用放在任何類型的管理作用域中,比如 Servlet 架構中的 HttpSession。如果你現在正在使用一種 Web 框架,要考慮 SqlSession 放在一個和 HTTP 請求對象相似的作用域中。換句話說,每次收到的 HTTP 請求,就可以打開一個 SqlSession,返回一個響應,就關閉它。這個關閉操作是很重要的,你應該把這個關閉操作放到 finally 塊中以確保每次都能執行關閉。下面的示例就是一個確保 SqlSession 關閉的標準模式:

SqlSession session = sqlSessionFactory.openSession();
try {
  // do work
} finally {
  session.close();
}

在你的所有的代碼中一致性地使用這種模式來保證所有數據庫資源都能被正確地關閉。

映射器實例(Mapper Instances)

映射器是創建用來綁定映射語句的接口。映射器接口的實例是從 SqlSession 中獲得的。因此從技術層面講,映射器實例的最大作用域是和 SqlSession 相同的,因為它們都是從 SqlSession 裏被請求的。盡管如此,映射器實例的最佳作用域是方法作用域。也就是說,映射器實例應該在調用它們的方法中被請求,用過之後即可廢棄。並不需要顯式地關閉映射器實例,盡管在整個請求作用域(request scope)保持映射器實例也不會有什麽問題,但是很快你會發現,像 SqlSession 一樣,在這個作用域上管理太多的資源的話會難於控制。所以要保持簡單,最好把映射器放在方法作用域(method scope)內。下面的示例就展示了這個實踐:

SqlSession session = sqlSessionFactory.openSession();
try {
  BlogMapper mapper = session.getMapper(BlogMapper.class);
  // do work
} finally {
  session.close();
}

MyBatis入門