mybatis使用總結 (基礎)

ssm框架中學習過程當中較簡單的一個框架。java

MyBatis (ibatis)是一款優秀的持久層框架,它支持定製化 SQL、存儲過程以及高級映射。MyBatis 避免了幾乎全部的 JDBC 代碼和手動設置參數以及獲取結果集。(百度百科)mysql

也就是說mybatis使數據庫sql語句與Java代碼「分開」,下降耦合,而且對於數據庫語句的書寫也比傳統的jdbc要簡單許多。sql

使用數據庫

 

 

 

1. 建立一個maven項目,在pom文件中導入相關jar包依賴。獲取mybatis,SQL server數據庫驅動jar包apache

<dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.3</version>
 </dependency>

<dependency>
            <groupId>com.microsoft.sqlserver</groupId>
            <artifactId>mssql-jdbc</artifactId>
            <version>7.0.0.jre10</version>
</dependency>

 

2. 建立mybatis核心配置文件,mybatis-config.xmlsession

<?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="sql">
        <environment id="sql">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/>
                <property name="url" value="jdbc:sqlserver://localhost:1433;databaseName=TestData"/>
                <property name="username" value="sa"/>
                <property name="password" value="123456"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/cheng/dao/UserMapper.xml"/>
    </mappers>

</configuration>

Mybatis默認的事務管理器就是 JDBC , 鏈接池 : POOLEDmybatis

MyBatis 的配置文件包含了會深深影響 MyBatis 行爲的設置和屬性信息。app

configuration(配置)
properties(屬性)
settings(設置)
typeAliases(類型別名)
typeHandlers(類型處理器)
objectFactory(對象工廠)
plugins(插件)
environments(環境配置)
environment(環境變量)
transactionManager(事務管理器)
dataSource(數據源)
databaseIdProvider(數據庫廠商標識)
mappers(映射器)框架

 

例:typeAliases(類型別名)設置maven

 <!-- 定義 別名 -->
    <typeAliases>

        <!--單個別名的定義  alias:別名,type:別名映射的類型  -->
        <!-- <typeAlias type="cn.itcast.mybatis.po.User" alias="user"/> -->

        <!-- 批量別名定義
        指定包路徑,自動掃描包下邊的pojo,定義別名,別名默認爲類名(首字母小寫或大寫)
         -->
        <package name="com.cheng.pojo"/>

    </typeAliases>

若批量定義別名後,mapper映射文件中。

       <-- 未定義別名-->
    <select id="getUserList" resultType="com.cheng.pojo.User">
       select * from sqldata
   </select>

    <insert id="addUser" parameterType="com.cheng.pojo.User">
        insert into sqldata (id,name,pwd) values(#{id},#{name},#{pwd});
    </insert>

    <--已定義別名 -->
    <select id="getUserList" resultType="User">
       select * from sqldata
   </select>

    <insert id="addUser" parameterType="User">
        insert into sqldata (id,name,pwd) values(#{id},#{name},#{pwd});
    </insert>

 

例:經過properties屬性來實現引用配置文件(鏈接數據庫)

鏈接SQL server數據庫的 db.properties

driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
url=jdbc:sqlserver://localhost:1433;databaseName=TestData
username=sa
password=123456

鏈接mysql數據庫的 db.properties

driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/jdbc?useSSL=false&serverTimezone=UTC
username=root
password=123456

引用.properties文件

......
......
    <properties resource="db.properties"/>

    <environments default="sql">
        <environment id="sql">
            <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>
......
......

 

例:mappers(映射器)

<!--每個Mapper.XML都須要在Mybatis核心配置文件中註冊!-->

<-- 方式一: 【推薦使用】-->
    <mappers>
        <mapper resource="com/cheng/dao/UserMapper.xml"/>
    </mappers>

<-- 方式一: 使用class文件綁定註冊-->
<mappers>
    <mapper class="com.cheng.dao.UserMapper"/>
</mappers>

 

3. 編寫mybatis工具類

//sqlSessionFactory --> sqlSession
public class MybatisUtils {

    private static SqlSessionFactory sqlSessionFactory;

    static{
        try {
            //使用Mybatis第一步:獲取sqlSessionFactory對象
            String resource = "mybatis-config.xml";
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

    //既然有了 SqlSessionFactory,顧名思義,咱們就能夠從中得到 SqlSession 的實例了。
    // SqlSession 徹底包含了面向數據庫執行 SQL 命令所需的全部方法。
    public static SqlSession  getSqlSession(){
        return sqlSessionFactory.openSession();
    }

}

 

4. pojo層編寫實體類,類實例域要與數據庫中列中屬性相對應,名稱相同(不相同也能夠

package com.cheng.pojo;

import lombok.*;

@Setter  //生成set方法,final變量不包含
@Getter  //生成get方法,final變量不包含
@AllArgsConstructor  //生成全部參數的構造方法
/*
@NoArgsConstructor  //生成無參構造方法
@ToString   //生成全部屬性的toString()方法
@EqualsAndHashCode  //生成生成equals()方法和hashCode方法
@Data   //包括@Setter/@Getter,@ToString ,@EqualsAndHashCode,@RequiredArgsConstructor
@RequiredArgsConstructor    //生成一個包含 "特定參數" 的構造器,特定參數指的是那些有加上 final 修飾詞的變量.
// 若是全部的變量都是正常的,都沒有用 final 修飾的話,那就會生成一個沒有參數的構造器
*/
public class User {
    private int id;
    private String name;
    private String pwd;

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name.trim() + '\'' +
                ", pwd='" + pwd.trim() + '\'' +
                '}';
    }
}

 

5. dao層接口,並編寫映射文件 UserDao.xml(接口實現類由原來的UserDaoImpl轉變爲一個 Mapper配置文件)

package com.cheng.dao;

import com.cheng.pojo.User;

import java.util.List;

public interface UserDao {
    //查詢所有信息
    List<User> getUserList();

    //根據id查詢
    List<User> getUserListById(int id);

    //插入信息
    void addUser(User user);

    //修改用戶
    void updateUser(User user);

    //刪除用戶
    void deleteUser(int id);

}

映射文件

  namespace中的包名要和 Dao/mapper 接口的包名一致!

  id : 就是對應的namespace中的方法名。

  resultType:Sql語句執行的返回值。

  parameterType : 參數類型。

<?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.cheng.dao.UserDao">

    <select id="getUserList" resultType="com.cheng.pojo.User">
       select * from sqldata
   </select>

    <select id="getUserListById" resultType="com.cheng.pojo.User" parameterType="int">
        select * from sqldata where id=#{id}
    </select>

    <insert id="addUser" parameterType="com.cheng.pojo.User">
        insert into sqldata (id,name,pwd) values(#{id},#{name},#{pwd});
    </insert>

    <update id="updateUser" parameterType="com.cheng.pojo.User">
        update sqldata set name=#{name},pwd=#{pwd} where id=#{id}
    </update>

    <delete id="deleteUser" parameterType="int">
        delete from sqldata where id=#{id};
    </delete>

</mapper>

 

單元測試

import com.cheng.pojo.User;
import com.cheng.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.util.List;

public class JTest {

    @Test
    public void test(){
        //第一步:得到SqlSession對象
        SqlSession sqlSession;
        sqlSession = MybatisUtils.getSqlSession();

        //方式一:getMapper
        UserDao userDao = sqlSession.getMapper(UserDao.class);
        List<User> userList = userDao.getUserList();

        for (User user : userList) {
            System.out.println(user);
        }

        //關閉SqlSession
        sqlSession.close();
    }

    @Test
    public  void test2(){
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        UserDao mapper = sqlSession.getMapper(UserDao.class);
        List<User> userListById = mapper.getUserListById(1);
        System.out.println(userListById);
        sqlSession.close();
    }

    //增刪改須要提交事務
    @Test
    public  void test3(){
       SqlSession sqlSession =MybatisUtils.getSqlSession();
       UserDao userDao=sqlSession.getMapper(UserDao.class);
       userDao.addUser(new User(3,"YuQingSong","123456"));
       sqlSession.commit(); //提交事務
       sqlSession.close();
    }
}
相關文章
相關標籤/搜索