使用mybatis自动创建实体类model和DAO方法mapper
使用mybatis自动创建实体类model和DAO方法mapper一、为什么使用mybatis二、在maven项目中使用mybatis1、在maven项目中添加mybatis的支持1.1导入相关依赖1.2添加web的支持1.3在线安装free mybtais plugin 插件1.4mybatis的核心配置文件1.5添加mybatis日志配置1.6创建MybatisSessionFactoryUt
使用mybatis自动创建实体类model和DAO方法mapper
一、为什么使用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">-->
<!-- <!– 忽略列,不生成bean 字段 –>-->
<!-- <!– <ignoreColumn column="FRED" /> –>-->
<!-- <!– 指定列的java数据类型 –>-->
<!-- <!– <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> –>-->
<!-- </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
更多推荐
所有评论(0)