天天看點

SpringBoot2.x 自動化生成代碼整合Mybatis

前言

Mybatis 是一個持久層ORM架構,負責Java與資料庫資料互動,也可以簡易了解為中介,相對于它,還有個中介是hibernate,不過在mybatis中sql語句的靈活性,可優化性比較強,這也是現在大多數人選擇的原因。

1. mapper.xml、dao接口、實體類自動生成

下載下傳 pan.baidu.com/s/1JY7Xduk5… 工具包
SpringBoot2.x 自動化生成代碼整合Mybatis

1.1 修改配置檔案generator.xml

解壓之後,這裡把檔案拷貝到了C:\resources\generator檔案夾下,以下稱為"目前檔案目錄"

一次配置,終身受益

generator.xml

<?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>
    <!-- 資料庫驅動包位置 也就是剛解壓的檔案的位置加上 mysql-connector-java-5.1.34.jar-->
    <classPathEntry location="C:\resources\generator\mysql-connector-java-5.1.34.jar" />
    <!--這裡也适用Oracle資料庫的自動生成-->
    <!-- <classPathEntry location="C:\resources\generator\ojdbc6.jar" /> -->
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <commentGenerator>
            <!-- 去除生成日期 -->
            <property name="suppressDate" value="true"/>
            <!-- 去除所有的注解 -->
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!-- 資料庫連結URL、使用者名、密碼 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/ceilan" userId="root" password="123456">
        <!-- <jdbcConnection driverClass="oracle.jdbc.driver.OracleDriver" connectionURL="jdbc:oracle:thin:@localhost:1521:orcl" userId="scott" password="tiger">-->
        </jdbcConnection>
        <!--java類型處理器-->
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>
        <!-- 生成模型的包名和位置 -->
        <javaModelGenerator targetPackage="com.example.entity" targetProject="C:\resources\generator\src">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <!-- 生成的映射檔案包名和位置 -->
        <sqlMapGenerator targetPackage="mapping" targetProject="C:\resources\generator\src">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>
        <!-- 生成DAO的包名和位置 -->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.dao" targetProject="C:\resources\generator\src">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>
        <!-- 要生成哪個表,更改tableName(資料庫裡表名)和domainObjectName(實體名,一般首字母大寫)就可以 -->
        <table tableName="area" domainObjectName="Area" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" />
    </context>
</generatorConfiguration>

           

1.2 用Java運作自動生成

在目前目錄下打開cmd指令,運作如下

注 : windows系統可直接執行 [ 生成.bat ] 批處理檔案

java -jar mybatis-generator-core-1.3.2.jar -configfile generator.xml -overwrite

           
SpringBoot2.x 自動化生成代碼整合Mybatis

然後把目前目錄src下的com檔案夾拷貝到項目檔案夾下

把mapping檔案拷貝到resources檔案夾下

SpringBoot2.x 自動化生成代碼整合Mybatis

目錄結構如上

2.內建Mybatis架構

2.1 引入依賴

compile "mysql:mysql-connector-java:5.1.39"
compile 'org.mybatis.spring.boot:mybatis-spring-boot-starter:1.2.0'

           

2.2 啟動類DemoApplication.java增加掃描配置

package com.example;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.web.bind.annotation.RequestMapping;

@SpringBootApplication
// mapper接口 掃描包配置
@MapperScan(value = "com.example.dao")
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}

           

2.3 添加項目首頁index.html

在resources的templates檔案中建立index.html

index.html

<!DOCTYPE html>
<html >
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>Welcome SpringBoot</h1>
</body>
</html>

           

然後在 DemoApplication 啟動類中添加

//歡迎頁面 首頁
    @RequestMapping("/")
    public String index(){
        return "index";
    }

           

之前已經在application.yml中配置了資源映射設定,如下

spring: 
  mvc:
    view:
      suffix: .html
  resources:
    static-locations: classpath:/templates

           

是以現在的項目啟動通路 http://localhost:8080/ 是可以直接通路到首頁的

3.添加業務層和控制層實作CRUD(增删改查)

增加業務邏輯層包service以及在其下增加impl包用來實作其接口

3.1業務邏輯層接口 AreaService.java

package com.example.service;

import com.example.entity.Area;

/**
 * 這裡給dao層的代碼拷貝過來先使用
 * created by cfa  2018-11-08 下午 9:56
 **/
public interface AreaService {

    int deleteByPrimaryKey(Integer id);

    int insert(Area record);

    int insertSelective(Area record);

    Area selectByPrimaryKey(Integer id);

    int updateByPrimaryKeySelective(Area record);

    int updateByPrimaryKey(Area record);
}

           

3.2業務層實作類 AreaServiceImpl.java

package com.example.service.impl;

import com.example.dao.AreaMapper;
import com.example.entity.Area;
import com.example.service.AreaService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.io.Serializable;

/**
 * 這裡的@Service注解相當于自動注冊到Spring的Bean
 * 相當于原來的Application.xml裡的 <bean id="areaServiceImpl" class="com.example.service.impl.AreaServiceImpl"/>
 * created by cfa  2018-11-08 下午 9:58
 **/
@Service
public class AreaServiceImpl implements AreaService, Serializable {

    private final AreaMapper areaMapper;

    @Autowired
    public AreaServiceImpl(AreaMapper areaMapper) {
        this.areaMapper = areaMapper;
    }

    @Override
    public int deleteByPrimaryKey(Integer id) {
        return areaMapper.deleteByPrimaryKey(id);
    }

    @Override
    public int insert(Area record) {
        return areaMapper.insert(record);
    }

    @Override
    public int insertSelective(Area record) {
        return areaMapper.insertSelective(record);
    }

    @Override
    public Area selectByPrimaryKey(Integer id) {
        return areaMapper.selectByPrimaryKey(id);
    }

    @Override
    public int updateByPrimaryKeySelective(Area record) {
        return areaMapper.updateByPrimaryKeySelective(record);
    }

    @Override
    public int updateByPrimaryKey(Area record) {
        return areaMapper.updateByPrimaryKey(record);
    }
}

           

3.3控制層的AreaController.java

package com.example.controller;

import com.example.entity.Area;
import com.example.service.AreaService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("area")
public class AreaController {

    private final AreaService areaService;

    @Autowired
    public AreaController(AreaService areaService) {
        this.areaService = areaService;
    }

    @RequestMapping("query")
    public Area areaList(){
        return areaService.selectByPrimaryKey(1);
    }

}

           

看到這裡,想必看到很多次@Autowired,@Service等注解了,這就是Spring的兩大核心之一的IOC(Inversion of Control),也就是DI依賴注入;

Spring的兩大核心AOP和IOC大家面試的時候也基本都有問到,到這裡你IOC就不用頭疼了;

在Spring之前我們寫代碼,用到某個類,我們都需要去new一下,現在有個叫Spring,我把控制權交給它,OK,然後在給業務層蓋上章(加注解),然後讓這個叫Spring的家夥開始工作的時候,交給他去做,控制層需要邏輯A,OK,之前我們已經在控制層用DI注入了A,Spring就會把A的調用給控制層,下面說松緊耦合度,Spring之前,到處寫的都是new建立對象,修改一個類很難,現在随意修改,隻需要蓋個章(DI),讓Spring去管就可以了,你現在要問我原理,那些文鄒鄒的,後續在研究研究,原理相當于文言文,隻有研究透了,才能用大家都了解的話寫出來。

業務層提供的接口加實作類就是為了實作松耦合,不然一個類就解決了,就像一個手機,壞了,裡面的電池,螢幕,主機闆什麼的拆下來還能用,這就是松耦合。

4.熱部署插件

問題:你為什麼不選擇springboot自帶的熱部署插件

答: 和之前的朋友問我的一樣,問我為啥不把生成代碼的插件放在項目中,一個項目還好,你要是寫了多個項目,一個一個去部署,麻煩不,是以一次配置,一勞永逸。

5.關于AOP——Spring的又一大核心

面向切面程式設計(AOP是Aspect Oriented Program的首字母縮寫)我們知道,面向對象的特點是繼承、多态和封裝.而封裝就要求将功能分散到不同的對象中去,這在軟體設計中往往稱為職責配置設定.實際上也就是說,讓不同的類設計不同的方法。這樣代碼就分散到一個個的類中去了。這樣做的好處是降低了代碼的複雜程度,使類可重用.但是人們也發現,在分散代碼的同時,也增加了代碼的重複性.什麼意思呢?比如說,我們在兩個類中,可能都需要在每個方法中做日志。按面向對象的設計方法,我們就必須在兩個類的方法中都加入日志的内容。也許他們是完全相同的,但就是因為面向對象的設計讓類與類之間無法聯系,而不能将這些重複的代碼統一起來。 也許有人會說,那好辦啊,我們可以将這段代碼寫在一個獨立的類獨立的方法裡,然後再在這兩個類中調用。但是,這樣一來,這兩個類跟我們上面提到的獨立的類就有耦合了,它的改變會影響這兩個類。那麼,有沒有什麼辦法,能讓我們在需要的時候,随意地加入代碼呢?這種在運作時,動态地将代碼切入到類的指定方法、 指定位置上的程式設計思想就是面向切面的程式設計。 一般而言,我們管切入到指定類指定方法的代碼片段稱為切面,而切入到哪些類、哪些方法則叫切入點。有了AOP,我們就可以把幾個類共有的代碼,抽取到一個切片中,等到需要時再切入對象中去,進而改變其原有的行為。 這樣看來,AOP其實隻是OOP的補充而已。OOP從橫向上區分出一個個的類來,而AOP則從縱向上向對象中加入特定的代碼。有了AOP,OOP變得立體了。如果加上時間次元,AOP使OOP由原來的二維變為三維了,由平面變成立體了。從技術上來說,AOP基本上是通過代理機制實作的。 AOP在程式設計曆史上可以說是裡程碑式的,對OOP程式設計是一種十分有益的補充 引自:xiaobashagua.iteye.com/blog/196368…你問我為啥排這麼緊,哈哈,好東西是留給有耐心的人看的,如果你把這篇文章的IOC和AOP仔細看了,你會對這倆的了解又深了一個層次