一、为什么使用mybatis

mybatis是一个基于java的持久层框架(半自动),主要包括SQL Map和Data Access Oject(DAO);
MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。
MyBatis使用简单的XML或注解用于噢诶之和原始的映射,将接口和java的POJOs(Plain Old Java Object 普通的Java 对象)映设成数据库中的记录;
每一个MyBatis应用程序主要都是使用SqlSession实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得,SqlSessionFactoryBuilder 可以从一个xml的配置文件或者一个预定义的配置类的实例获得。
简化了一个开发的步骤,提高了开发的效率,灵活性较高,更能满足当前的企业中因为需求问题而需要修改的代码的要求,降低了因为人为因素导致的错误;

二、在maven项目中使用mybatis

1、在maven项目中添加mybatis的支持

1.1导入相关依赖

      junit 4.12//测试类的依赖
      javax.servlet-api 4.0.0//支持servlet的依赖
      mybatis 3.4.5//支持mybatis的依赖
      mysql-connector-java 5.1.44//支持连接的依赖

1.2添加web的支持

<!--禁止自动初始化log4j2 -->
    <context-param>
        <param-name>isLog4jAutoInitializationDisabled</param-name>
        <param-value>false</param-value>
    </context-param>

1.3在线安装free mybtais plugin 插件

在这里插入图片描述

在这个里面搜索然后直接安装即可

1.4mybatis的核心配置文件

mybatis.cfg.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="jdbc.properties"/>

    <!--开启日志记录-->
    <settings>
        <setting name="logImpl" value="LOG4J2"/>
    </settings>

    <!-- 配置mybatis运行环境 -->
    <environments default="development">
        <environment id="development">
            <!-- type="JDBC" 代表使用JDBC的提交和回滚来管理事务 -->
            <transactionManager type="jdbc"/>

            <!-- mybatis提供了3种数据源类型,分别是:POOLED,UNPOOLED,JNDI -->
            <!-- POOLED 表示支持JDBC数据源连接池 -->
            <!-- UNPOOLED 表示不支持数据源连接池 -->
            <!-- JNDI 表示支持外部数据源连接池 -->
            <dataSource type="POOLED">
                <property name="driver"
                          value="${jdbc.driver}"/>
                <property name="url"
                          value="${jdbc.url}"/>
                <property name="username" value="${jdbc.username}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
    <mapper class="com.zking.ssm1.mapper.BookMapper"/>
</mappers>

</configuration>

在这个mybatis.cfg.xml里面引用了jdbc.properties 这个是连接数据库的一些数据,包括连接字符串,数据库名字等都在其中

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/sys?useUnicode=true&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=123

1.5添加mybatis日志配置

在pom.xml里面配置log4j2
有比较多的日志配置,但今天我们在这里使用的是log4j2的日志记录依赖

<!--核心log4j2jar包--> 
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.9.1</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.9.1</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要--> 
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-web</artifactId>
    <version>2.9.1</version>
</dependency>

要记住在mybatis.cfg.xml这个里面需要调用这个log4j的配置

<setting name="logImpl" value="LOG4J2"/>

添加这个即可
上面添加已经在web中支持禁止自动初始化log4j

1.6创建MybatisSessionFactoryUtils进行测试

看这些配置能否正常连接到数据库

package com.zking.ssm1.uitle;

import java.io.InputStream;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class MybatisSessionFactoryUtils {

	public static SqlSessionFactory sqlSessionFactory;

	private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>();

	static {
		try {
			InputStream is = MybatisSessionFactoryUtils.class
					.getResourceAsStream("/mybatis.cfg.xml");
			SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
			sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
		} catch (Exception e) {
			throw new RuntimeException(e);
		}
	}

	private MybatisSessionFactoryUtils() {
	}

	public static SqlSession openSession() {
		SqlSession sqlSession = threadLocal.get();
		if (null == sqlSession) {
			sqlSession = sqlSessionFactory.openSession();
			threadLocal.set(sqlSession);
		}
		return sqlSession;
	}

	public static void closeSession() {
		SqlSession sqlSession = threadLocal.get();
		if (null != sqlSession) {
			threadLocal.set(null);
			sqlSession.close();
		}
	}
	
	public static void main(String[] args) {
		SqlSession sqlSession = MybatisSessionFactoryUtils.openSession();
		System.out.println(sqlSession);
		System.out.println(sqlSession.getConnection());
		MybatisSessionFactoryUtils.closeSession();
	}

}

直接运行这个类即可

2.7创建MyBatis-generator 命令让他自动生成MyBatis代码

在这里插入图片描述
点击这个Edit Configurations创建命令即可是,在这个上方添加maven命令即可,弹出框,Command line 输入这个命令即可

mybatis-generator:generate -e

在这里插入图片描述

2.8添加这个命令的插件,添加组合依赖

在pom.xml中添加这个

 <!--集成mybatis和maven的插件-->
        <plugin>
          <groupId>org.mybatis.generator</groupId>
          <artifactId>mybatis-generator-maven-plugin</artifactId>
          <version>1.3.2</version>
          <dependencies>
            <dependency>
              <groupId>mysql</groupId>
              <artifactId>mysql-connector-java</artifactId>
              <version>5.1.44</version>
            </dependency>
          </dependencies>
          <configuration>
            <overwrite>true</overwrite>
          </configuration>
        </plugin>

2.9 创建generatorConfig.xml,作为mybatis-generator-maven-plugin插件的执行目标

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
<generatorConfiguration>
    <!-- 引入配置文件 -->
    <properties resource="jdbc.properties"/>

    <!--指定数据库jdbc驱动jar包的位置-->
    <classPathEntry location="D:\\repository\\mvn\\mysql\\mysql-connector-java\\5.1.44\\mysql-connector-java-5.1.44.jar"/>

    <!-- 一个数据库一个context -->
    <context id="infoGuardian">
        <!-- 注释 -->
        <commentGenerator>
            <property name="suppressAllComments" value="true"/><!-- 是否取消注释 -->
            <property name="suppressDate" value="true"/> <!-- 是否生成注释代时间戳 -->
        </commentGenerator>

        <!-- jdbc连接 -->
        <jdbcConnection driverClass="${jdbc.driver}"
                        connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}"/>

        <!-- 类型转换 -->
        <javaTypeResolver>
            <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) -->
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

        <!-- 01 指定javaBean生成的位置 -->
        <!-- targetPackage:指定生成的model生成所在的包名 -->
        <!-- targetProject:指定在该项目下所在的路径  -->
        <javaModelGenerator targetPackage="com.zking.ssm1.model"
                            targetProject="src/main/java">
            <!-- 是否允许子包,即targetPackage.schemaName.tableName -->
            <property name="enableSubPackages" value="false"/>
            <!-- 是否对model添加构造函数 -->
            <property name="constructorBased" value="true"/>
            <!-- 是否针对string类型的字段在set的时候进行trim调用 -->
            <property name="trimStrings" value="false"/>
            <!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 -->
            <property name="immutable" value="false"/>
        </javaModelGenerator>

        <!-- 02 指定sql映射文件生成的位置 -->
        <sqlMapGenerator targetPackage="com.zking.ssm1.mapper"
                         targetProject="src/main/java">
            <!-- 是否允许子包,即targetPackage.schemaName.tableName -->
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>

        <!-- 03 生成XxxMapper接口 -->
        <!-- type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象 -->
        <!-- type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象 -->
        <!-- type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口 -->
        <javaClientGenerator targetPackage="com.zking.ssm1.mapper"
                             targetProject="src/main/java" type="XMLMAPPER">
            <!-- 是否在当前路径下新加一层schema,false路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] -->
            <property name="enableSubPackages" value="false"/>
        </javaClientGenerator>

        <!-- 配置表信息 -->
        <!-- schema即为数据库名 -->
        <!-- tableName为对应的数据库表 -->
        <!-- domainObjectName是要生成的实体类 -->
        <!-- enable*ByExample是否生成 example类 -->
<!--        <table schema="" tableName="t_book" domainObjectName="Book"-->
<!--               enableCountByExample="false" enableDeleteByExample="false"-->
<!--               enableSelectByExample="false" enableUpdateByExample="false">-->
<!--            &lt;!&ndash; 忽略列,不生成bean 字段 &ndash;&gt;-->
<!--            &lt;!&ndash; <ignoreColumn column="FRED" /> &ndash;&gt;-->
<!--            &lt;!&ndash; 指定列的java数据类型 &ndash;&gt;-->
<!--            &lt;!&ndash; <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> &ndash;&gt;-->
<!--        </table>-->

    </context>
</generatorConfiguration>

2.10 将xml文件放入到target文件中,添加依赖

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

    <resource>
          <directory>src/main/resources</directory>
          <includes>
            <include>jdbc.properties</include>
             <include>*.xml</include>     
          </includes>
       </resource>
   
       </build>

一般在正常情况下,target文件中不会编译xml文件,需要手动添加依赖把这写文件放入到其中

完成上面的操作就可以正常测试了,就能自动生产mapper ,model

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐