SpringBoot入门到跑路之实战篇(二、数据源配置)

先引入依赖:

 当然不会让你们手敲,肯定可编辑啊;

        <!--加入Spring boot和MySQL的依赖 这个网上都有,我只做个总结-->
		<dependency>
			<groupId>org.mybatis.spring.boot</groupId>
			<artifactId>mybatis-spring-boot-starter</artifactId>
			<version>1.0.2</version>
		</dependency>
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>5.1.31</version>
		</dependency>

然后这里有个Mybatis自动生成工具:

下载地址(两个随便哪个都可以,因为担心出问题):

https://pan.baidu.com/s/1JY7Xduk5E3KPm58AjnueuQ

https://download.csdn.net/download/select_bin/10860496(不过这个有点坑,最少得一个积分)

使用:里面有详细描述,

这里再写一遍:

下载 :

https://pan.baidu.com/s/1JY7Xduk5E3KPm58AjnueuQ 工具包

1.1 修改配置文件generator.xml
解压之后,这里把文件拷贝到了C:\resources\generator文件夹下,以下称为"当前文件目录"
一次配置,终身受益

<?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>
    <!-- 数据库驱动包位置 -->
    <classPathEntry location="C:\resources\generator\mysql-connector-java-5.1.34.jar" />
    <!-- <classPathEntry location="D:\app\pony\product\11.2.0\dbhome_1\jdbc\lib\ojdbc6.jar" /> -->
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <commentGenerator>
            <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>
        <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="wbconfig" domainObjectName="Wbconfig" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" />
        <!-- <table tableName="triggers" domainObjectName="Triggers" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false" />   -->
        <!-- <table tableName="lenovo_work_list" domainObjectName="lenovoWorkList" 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

然后把当前目录src下的com文件夹拷贝到项目文件夹下

把mapping文件拷贝到resources文件夹下

2.2 启动类DemoApplication.java增加扫描配置

package com.example;

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

@SpringBootApplication
// mapper接口 扫描包配置
@MapperScan(value = "com.example.dao")
public class SelectBinApplication {
	public static void main(String[] args) {

		SpringApplication.run(SelectBinApplication.class, args);
	}

}

 然后在 SelectBinApplication 启动类中添加

    /**
     * @param
     * @return
     * @throws
     * @Description: 欢迎页面 首页
     * @author liu
     * @date 2018/12/19 11:10
     */
    @RequestMapping("/")
    public String index() {
        return "index";
    }

2.3 添加项目首页index.html

在resources的templates文件中新建index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<h1>
    Welcome SpringBoot
</h1>
</body>
</html>

在application.yml中配置资源映射设置,如下:

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

所以现在的项目启动访问 http://localhost:8080/ 是可以直接访问到首页的

3.添加业务层和控制层实现CRUD(增删改查)

写到这里发现自己本地没装MySQL太麻烦了,还是装一个吧;

参考这个文章:http://www.cnblogs.com/laumians-notes/p/9069498.html

中间有这个错:

 是因为my.ini里面路径忘记改了,路径一共两处,第二个地方记得在最后面加/Data,不然第二行还是会报错;

MySQL装好了之后,

增加业务逻辑层包service以及在其下增加impl包用来实现其接口

3.1业务逻辑层接口 IMenuService.java

package com.example.service;

import com.example.entity.td_sys_menu;

import java.util.List;

/**
 * @version 1.0
 * @ClassName IMenuService
 * @Description todo
 * @Author 74981
 * @Date 2018/12/19 16:06
 */
public interface IMenuService {
    /**
     * @Description: 获取当前所有菜单列表
     * @param
     * @return
     * @throws
     * @author liu
     * @date 2018/12/19 16:06
     */
    List<td_sys_menu> getAllMenuList();
}

3.2业务层实现类 MenuService.java

package com.example.service.impl;

import com.example.dao.td_sys_menuMapper;
import com.example.entity.td_sys_menu;
import com.example.entity.td_sys_menuKey;
import com.example.service.IMenuService;
import org.springframework.beans.factory.annotation.Autowired;

import java.util.List;

/**
 * @version 1.0
 * @ClassName MenuService
 * @Description todo
 * @Author 74981
 * @Date 2018/12/19 16:06
 */
public class MenuService implements IMenuService {

    @Autowired
    td_sys_menuMapper sysMenuMapper;

    @Override
    public List<td_sys_menu> getAllMenuList() {
        return sysMenuMapper.selectAll();
    }
}

3.3控制层的MenuController.java

package com.example.controller;

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

import java.util.List;

/**
 * @version 1.0
 * @ClassName MenuController
 * @Description todo
 * @Author 74981
 * @Date 2018/12/19 16:20
 */
@RestController
@RequestMapping("menu")
public class MenuController {

    @Autowired
    IMenuService menuService;
    public List<td_sys_menu>  getAllMenuController(){
        return menuService.getAllMenuList();
    }
}

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

Spring的两大核心AOP和IOC大家面试的时候也基本都有问到,到这里你IOC就不用头疼了;

我前面的文章有对IOC和AOP的一点小小的解释,比较浅,大家可以看一下;

在Spring之前我们写代码,用到某个类,我们都需要去new一下,现在有个叫Spring,我把控制权交给它,OK,然后在给业务层盖上章(加注解),然后让这个叫Spring的家伙开始工作的时候,交给他去做,控制层需要逻辑A,OK,之前我们已经在控制层用DI注入了A,Spring就会把A的调用给控制层,下面说松紧耦合度,Spring之前,到处写的都是new新建对象,修改一个类很难,现在随意修改,只需要盖个章(DI),让Spring去管就可以了,你现在要问我原理,那些文邹邹的,后续在研究研究,原理相当于文言文,只有研究透了,才能用大家都理解的话写出来。

业务层提供的接口加实现类就是为了实现松耦合,不然一个类就解决了,就像一个手机,坏了,里面的电池,屏幕,主板什么的拆下来还能用,这就是松耦合。

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

面向切面编程(AOP是Aspect Oriented Program的首字母缩写)我们知道,面向对象的特点是继承、多态和封装.而封装就要求将功能分散到不同的对象中去,这在软件设计中往往称为职责分配.实际上也就是说,让不同的类设计不同的方法。这样代码就分散到一个个的类中去了。

这样做的好处是降低了代码的复杂程度,使类可重用.但是人们也发现,在分散代码的同时,也增加了代码的重复性.什么意思呢?比如说,我们在两个类中,可能都需要在每个方法中做日志。按面向对象的设计方法,我们就必须在两个类的方法中都加入日志的内容。也许他们是完全相同的,但就是因为面向对象的设计让类与类之间无法联系,而不能将这些重复的代码统一起来。

也许有人会说,那好办啊,我们可以将这段代码写在一个独立的类独立的方法里,然后再在这两个类中调用。但是,这样一来,这两个类跟我们上面提到的独立的类就有耦合了,它的改变会影响这两个类。那么,有没有什么办法,能让我们在需要的时候,随意地加入代码呢?这种在运行时,动态地将代码切入到类的指定方法、 指定位置上的编程思想就是面向切面的编程。

一般而言,我们管切入到指定类指定方法的代码片段称为切面,而切入到哪些类、哪些方法则叫切入点。有了AOP,我们就可以把几个类共有的代码,抽取到一个切片中,等到需要时再切入对象中去,从而改变其原有的行为。

这样看来,AOP其实只是OOP的补充而已。OOP从横向上区分出一个个的类来,而AOP则从纵向上向对象中加入特定的代码。有了AOP,OOP变得立体了。如果加上时间维度,AOP使OOP由原来的二维变为三维了,由平面变成立体了。从技术上来说,AOP基本上是通过代理机制实现的。

AOP在编程历史上可以说是里程碑式的,对OOP编程是一种十分有益的补充 引自:http://xiaobashagua.iteye.com/blog/1963683你问我为啥排这么紧,哈哈,好东西是留给有耐心的人看的,如果你把这篇文章的IOC和AOP仔细看了,你会对这俩的理解又深了一个层次。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值