MyBatisPlus 3.x 入门使用

2018-10-03  本文已影响1165人  BzCoder

相关资料以及注意事项:

简介

MyBatisPlus是一个Mybatis的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。它主要通过启动时自动注入基本CURD,达到简化操作的目的。

快速开始

一.安装插件

安装MyBatisPlus提供的MybatisX插件。 IDEA搜索mybatisx安装即可。

二.Maven

    <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus</artifactId>
            <version>3.0.3</version>
        </dependency>

三.配置文件

主要配置了数据源以及MyBatisPlus中的一些配置选项,其他更多选项可以查看官方文档。当然在SpringBoot里配置会更加方便,这边展示的是SpringMVC中的配置方法。

applicationContext.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:mybatis-spring="http://mybatis.org/schema/mybatis-spring"
    xsi:schemaLocation="http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring-1.2.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd">
    
    
    <!-- 数据源 -->
    <context:property-placeholder location="classpath:db.properties"/>
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="driverClass" value="${jdbc.driver}"></property>
        <property name="jdbcUrl" value="${jdbc.url}"></property>
        <property name="user" value="${jdbc.username}"></property>
        <property name="password" value="${jdbc.password}"></property>
    </bean>
    
    <!-- 事务管理器 -->
    <bean id="dataSourceTransactionManager" 
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    <!-- 基于注解的事务管理 -->
    <tx:annotation-driven transaction-manager="dataSourceTransactionManager"/>

    <!-- 定义MybatisPlus的全局策略配置-->
    <bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean">
        <!-- 数据源 -->
        <property name="dataSource" ref="dataSource"/>

        <!--<property name="configLocation" value="classpath:mybatis-config.xml"/>-->

        <property name="configuration">
            <bean class="com.baomidou.mybatisplus.core.MybatisConfiguration">
                <!--开启下划线驼峰映射-->
                <property name="mapUnderscoreToCamelCase" value="true"/>
            </bean>
        </property>
        <!-- 别名处理 -->
        <property name="typeAliasesPackage" value="com.bzcoder.entity"/>
        <!-- 注入全局MP策略配置 -->
        <property name="globalConfig">
            <bean class="com.baomidou.mybatisplus.core.config.GlobalConfig">
                <property name="dbConfig">
                    <bean class="com.baomidou.mybatisplus.core.config.GlobalConfig.DbConfig">
                        <!--主键规则-->
                        <property name="idType" value="AUTO"/>
                        <!--表前缀-->
                        <property name="tablePrefix" value="tbl_"/>
                    </bean>
                </property>
            </bean>
        </property>
    </bean>
    <!-- 
        配置mybatis 扫描mapper接口的路径
     -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.bzcoder.mapper"></property>
    </bean>
</beans>

mybatis-config.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
 
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
 <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
   <param name="Encoding" value="UTF-8" />
   <layout class="org.apache.log4j.PatternLayout">
    <param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m  (%F:%L) \n" />
   </layout>
 </appender>
 <logger name="java.sql">
   <level value="debug" />
 </logger>
 <logger name="org.apache.ibatis">
   <level value="info" />
 </logger>
 <root>
   <level value="debug" />
   <appender-ref ref="STDOUT" />
 </root>
</log4j:configuration>

四.实体类以及Mapper

MyBatisPlus提供两种方法任你选择

public interface CompanyMapper extends BaseMapper<Company> {
}

使用方法:

   @Test
    public void insert() {
        Employee employee = new Employee();
        employee.setLastName("BZ");
        employee.setAge(27);
        employee.setEmail("123@qq.com");
        employeeMapper.insert(employee);
        System.out.println(employee.getId());
    }
/**
 * 活动模式
 * @author BaoZhou
 * @date 2018/10/1
 */
@Data
public class Company extends Model<Company> {
    @TableId(value = "id",type = IdType.AUTO)
    private Integer id;
    private String name;
    private String owner;
    private String location;
    private Integer status;
    /**
     * @return 返回当前表的主键
     */
    @Override
    protected Serializable pkVal() {
        return id;
    }
}

使用方法:

  @Test
    public void arInsert()
    {
        Company company = new Company();
        company.setOwner("bzz");
        company.setName("公司");
        company.setLocation("杭州");
        boolean insert = company.insert();
}

MyBatisPlus提供了以下基本方法:


MyBatisPlus提供的基本CRUD方法

配置完毕,接下来咱们就可以开始愉快地CRUD操作啦。

上一篇 下一篇

猜你喜欢

热点阅读