溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

spring怎么用mybatis-plus-gennretor代碼生成器生成代碼+分頁(yè)插件

發(fā)布時(shí)間:2021-06-30 15:30:29 來(lái)源:億速云 閱讀:206 作者:chen 欄目:大數(shù)據(jù)

本篇內(nèi)容介紹了“spring怎么用mybatis-plus-gennretor代碼生成器生成代碼+分頁(yè)插件”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

  • 代碼生成器

1導(dǎo)入需要的jar包

 <dependencies>
        <!-- mp依賴(lài)   mybaits-plus 會(huì)自動(dòng)維護(hù)mybaits  jar包 所以不用加入了 防止版本沖突 -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus</artifactId>
            <version>2.3</version>
        </dependency>
        <!-- junit -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
        <!-- log4j -->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <!-- c3p0 -->
        <dependency>
            <groupId>com.mchange</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.5.2</version>
        </dependency>
        <!-- mysql -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.37</version>
        </dependency>
        <!-- spring -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.3.10.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-orm</artifactId>
            <version>4.3.10.RELEASE</version>
        </dependency>

        <!-- Apache velocity -->
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.0</version>
        </dependency>

        <!-- sfl4j -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.7</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.7</version>
        </dependency>
    </dependencies>

2 配置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"
       xsi:schemaLocation="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">
    <!-- 數(shù)據(jù)源 -->
    <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>

    <!-- 事務(wù)管理器 事務(wù)管理器 -->
    <bean id="dataSourceTransactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"></property>
    </bean>
    <!-- 基于注解的事務(wù)管理 基于注解的事務(wù)管理 基于注解的事務(wù)管理 基于注解的事務(wù)管理 -->
    <tx:annotation-driven transaction-manager="dataSourceTransactionManager"/>
    <!-- 配置 SqlSessionFactoryBean -->
    <!--
        mybatis提供的:org.mybatis.spring.SqlSessionFactoryBean
        改成mybatis-plus提供的 :com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean
    -->
    <bean id="sqlSessionFactoryBean" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
        <!-- 數(shù)據(jù)源 -->
        <property name="dataSource" ref="dataSource"></property>
        <property name="configLocation" value="classpath:mybatis-config.xml"></property>
        <!-- 別名處理 別名處理 -->
        <property name="typeAliasesPackage" value="com.shi.entity"></property>

        <!--注入mybaits的全局策略配置-->
        <property name="globalConfig" ref="globalConfiguration"></property>
    </bean>
    <!-- 配置 mybatis 掃描 mapper接口的路徑 接口的路徑 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.shi.dao"></property>
    </bean>

    <!--定義全局的mybatisPlus的全局策略配置-->
    <bean id="globalConfiguration" class="com.baomidou.mybatisplus.entity.GlobalConfiguration">
        <!--駝峰命名法:在2.3版本之后 dbColumnUnderline 默認(rèn)就是true-->
        <property name="dbColumnUnderline" value="true"></property>
        <!--全局主鍵策略  0:表示自增主鍵 -->
        <property name="idType" value="0"></property>

    </bean>
</beans>

3 數(shù)據(jù)庫(kù)的配置

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://192.168.69.11:3306/shihaifeng
jdbc.username=用戶(hù)名
jdbc.password=密碼

4 生成代碼

package com.shi.test;

import com.baomidou.mybatisplus.enums.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.rules.DbType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.junit.Test;

/**
 * @author shfeng
 * @create 2019-07-18 16:59
 * 我的代碼自動(dòng)生成器
 */

public class MyGeneratorTest {

    @Test
    public void myGenerator(){
        //1 全局配置
        GlobalConfig globalConfig = new GlobalConfig();
        globalConfig.setActiveRecord(false) //是否支持AR模式
                    .setAuthor("shiye")    //作者
                    .setOutputDir("D:\\project\\shiTest\\shi_Mybatis_Plus\\src\\main\\java")    //設(shè)置生成路徑
                    .setFileOverride(true)  //文件覆蓋
                    .setIdType(IdType.AUTO) //主鍵策略 自增
                    .setServiceName("%sService")    //設(shè)置生成的servic接口的名字首字目去除I
                    .setBaseResultMap(true)     //生成sql mapper映射文件
                    .setBaseColumnList(true);

        //2 數(shù)據(jù)庫(kù)配置
        DataSourceConfig dataSourceConfig = new DataSourceConfig();
        dataSourceConfig.setDbType(DbType.MYSQL)    //設(shè)置數(shù)據(jù)庫(kù)類(lèi)型
                        .setDriverName("com.mysql.jdbc.Driver")      //設(shè)置數(shù)據(jù)驅(qū)動(dòng)
                        .setUrl("jdbc:mysql://192.168.69.11:3306/shihaifeng")         //設(shè)置數(shù)據(jù)庫(kù)url
                        .setUsername("")    //設(shè)置用戶(hù)名
                        .setPassword("");    //設(shè)置密碼

        //3 策略配置
        StrategyConfig strategyConfig = new StrategyConfig();
        strategyConfig.setCapitalMode(true) //全局大寫(xiě)命名
                    .setDbColumnUnderline(true) //指定表名字段名是否使用下劃線(xiàn)
                    .setNaming(NamingStrategy.underline_to_camel)   //數(shù)據(jù)庫(kù)表映射到實(shí)體的命名方法:駝峰命名法
                    .setTablePrefix("") //表的前綴
                    .setInclude("machine_item");    //需要生成的表

        //4 包名策略配置
        PackageConfig packageConfig = new PackageConfig();
        packageConfig.setParent("com.shi")      //全局父包
                    .setController("controller")
                    .setService("service")
                    .setServiceImpl("service.impl")
                    .setMapper("dao")    //dao接口
                    .setXml("dao")       //mapper映射文件
                    .setEntity("entity");

        //5 整合配置
        AutoGenerator autoGenerator = new AutoGenerator();
        autoGenerator.setGlobalConfig(globalConfig)
                    .setDataSource(dataSourceConfig)
                    .setStrategy(strategyConfig)
                    .setPackageInfo(packageConfig);

        //6 執(zhí)行
        autoGenerator.execute();

    }

}
  • 分頁(yè)插件

1.添加配置

(方法一:mybatis-config.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>

    <!-- 方法一:再改方法中添加mybatis-plus分頁(yè)插件 -->
    <!--<plugins>
        <plugin interceptor="com.baomidou.mybatisplus.plugins.PaginationInterceptor"></plugin>
    </plugins>-->
</configuration>

(方法二:applicationContext.xml)

<bean id="sqlSessionFactoryBean" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
        <!-- 數(shù)據(jù)源 -->
        <property name="dataSource" ref="dataSource"></property>
        <property name="configLocation" value="classpath:mybatis-config.xml"></property>
        <!-- 別名處理 別名處理 -->
        <property name="typeAliasesPackage" value="com.shi.entity"></property>

        <!--注入mybaits的全局策略配置-->
        <property name="globalConfig" ref="globalConfiguration"></property>

        <!-- 方法二:添加mybaits-plus 分頁(yè)插件 -->
        <property name="plugins">
            <list>
                <bean class="com.baomidou.mybatisplus.plugins.PaginationInterceptor"></bean>
            </list>
        </property>
    </bean>

2.測(cè)試

/**
     * 加入分頁(yè)插件 分頁(yè)使用物理分頁(yè)
     * SELECT id AS id,name_cn AS nameCn,name_us AS nameUs,`desc`,created,creater,updater,updated
     * FROM machine_item LIMIT 0,1
     */
    @Test
    public void testQueryByPage(){
        Page<MachineItem> page = new Page<MachineItem>(1,2);
        List<MachineItem> list = machineItemMapper.selectPage(page, null);
        System.out.println(list);

        System.out.println("*************獲取頁(yè)面的一些信息***************");
        System.out.println("總條數(shù)="+page.getTotal());
        System.out.println("當(dāng)前頁(yè)碼="+page.getCurrent());
        System.out.println("每一頁(yè)數(shù)量="+page.getSize());
        System.out.println("總頁(yè)數(shù)="+page.getPages());


        page.setRecords(list);
        System.out.println("總記錄="+page.getRecords());

    }

“spring怎么用mybatis-plus-gennretor代碼生成器生成代碼+分頁(yè)插件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI