单手撸了个springboot+mybatis+druid

本文旨在用最通俗的语言讲述最枯燥的基本知识css

最近身边的程序员掀起了学习springboot的热潮,说什么学会了springboot在大街上就能够横着走、什么有了springboot妈妈不再担忧个人编程了、什么BAT都喜欢的框架…听得做者那个心痒痒的,因而找了个时间,下载了个idea来玩一波springboot,对了…用springboot最好用idea,若是你还在用eclipse,删了吧。java

在这里解释一下为何是springboot+mybatis+druid,是由于做者认为但凡任何一个有灵魂的项目,都少不了数据库,做者不喜欢用JPA那种混SQL的语法,所以选了mybatis,而Druid是阿里系(真香~)的一种数据库链接池框架,在上一个项目做者用的屡试不爽,所以打算继续用,为啥屡试不爽?看文末吧。mysql

文章提纲:程序员

  1. 建立springboot工程
  2. 配置pom.xml
  3. 配置数据源
  4. 设置mybatis
  5. hello world
  6. 设置Druid监控配置

1. 建立springboot工程

只要你有idea,建立一个springboot工程,就跟捏死一个蚂蚁同样简单,由于idea里深度集成了对springboot项目的支持,你直接不停的next到最后,它就会帮你建立出一个springboot工程。spring

  1. 首先打开idea->Create New project->选择项目类型:这里选择spring initializr,而后next。
    sql

  2. 建立项目,填写项目名称,注意:不要能驼峰写法,能够用中横线,填写完毕后继续next。
    数据库

  3. 选择依赖,所谓依赖就是你在设计这个项目的框架时,分析这个项目须要用到哪些jar或者组件,好比缓存要用到Redis,数据库要用到MySQL等…这里由于演示项目,就不选择太多其它乱七八糟的依赖了。
    编程

  4. 选好依赖以后,又是一路狂点next,直到最后finish一下,一个springboot项目就建立好了。
    浏览器

2. 配置pom.xml

想一想,咱们须要哪些jar?
数据库要用到mybatis,数据库链接池要用到Druid、MySQL桥接器要用到mysql-connector,所以要maven仓库(点我去仓库)中找到搜索这些pom加进去。注意,mybatis要用mybatis-spring-boot-starter。缓存

 1       <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
2        <dependency>
3            <groupId>mysql</groupId>
4            <artifactId>mysql-connector-java</artifactId>
5            <version>5.1.6</version>
6        </dependency>
7        <!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
8        <dependency>
9            <groupId>com.alibaba</groupId>
10            <artifactId>druid</artifactId>
11            <version>1.1.10</version>
12        </dependency>
13        <!-- https://mvnrepository.com/artifact/org.mybatis.spring.boot/mybatis-spring-boot-starter -->
14        <dependency>
15            <groupId>org.mybatis.spring.boot</groupId>
16            <artifactId>mybatis-spring-boot-starter</artifactId>
17            <version>1.3.2</version>
18        </dependency>
复制代码

把上面这些pom放到pom.xml的dependencies中


细心的老铁会发现,MySQL的version里的内容是红色的,这是什么缘由呢?
这是由于咱们引入pom时,这些版本的jar在本地maven仓库尚未,而Druid的pom里的version没有显示红色,是由于以前的项目用到了这个版本的Druid,已经被下载到本地Maven仓库里了。
所以咱们须要把本地没有的jar下载到本地仓库,右键pom.xml弹出菜单,选择Maven,弹出菜单选择reimport

Reimport过程当中再idea底部会有进度条显示,等进度条消失,在观察pom.xml,红色已经消失,说明依赖已经装备完成。

  1. 配置数据源

接下来就是要多springboot项目作一个全局配置,默认会在src->main->resource目录下生产空白文件application.properties,做者喜欢用yml所以直接更名成yml便可。
首先是数据源的配置,下面是一份数据源的配置,每一个参数的解释都写了注释,所以读者能够直接复制一下内容进去,只须要改一下url、username、password

 1spring:
2  #profiles: dev
3  messages:
4    basename: i18n/Messages,i18n/Pages
5  datasource:
6    type: com.alibaba.druid.pool.DruidDataSource    # 配置当前要使用的数据源的操做类型
7    driver-class-name: org.gjt.mm.mysql.Driver        # 配置MySQL的驱动程序类
8    url: jdbc:mysql://localhost:3306/wkt_stat           # 数据库链接地址
9    username: root                                  # 数据库用户名
10    password: root                            # 数据库链接密码
11    dbcp2:                                          # 进行数据库链接池的配置
12      min-idle: 5                                   # 数据库链接池的最小维持链接数
13      initial-size: 5                               # 初始化提供的链接数
14      max-total: 5                                  # 最大的链接数
15      max-wait-millis: 200                          # 等待链接获取的最大超时时间
复制代码

4. 设置mybatis

继续在application.yml中设置mybatis,mybatis的配置也简单,
主要是为了设置mybatis的配置文件已经mapper文件所在。

  1. 首先在resource目录下建立一个mybatis-config.xml文件,文件内容为:
1<?xml version="1.0" encoding="UTF-8" ?>
2<!DOCTYPE configuration
3        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
4        "http://mybatis.org/dtd/mybatis-3-config.dtd">

5<configuration>
6    <mappers>
7    </mappers>
8</configuration>
复制代码
  1. 在main包中的根目录下建立一个存放mapper实体的资源文件,在resource文件下建立一个文件夹mapper用来存放mapper的xml文件。

  2. 配置好资源文件路径以后,就能够在application.yml中加入mybatis的配置了,以下是一个mybatis的配置内容:

1#mybatis的mapper配置文件
2mybatis:
3  config-location: classpath:mybatis-config.xml  # mybatis配置文件所在路径
4  #mapper-locations: classpath:mapper/*.xml   # 全部的mapper映射文件
5  type-aliases-package: com.becl.dao.mapper # 定义全部操做类的别名所在包
6debug: true
复制代码

最终application.yml的内容以下图:

  1. 此时须要有一个数据库表来作测试,咱们在数据库建立一个表,而且插入一条数据:
1CREATE TABLE Memeber (
2`id`  int(11) NOT NULL AUTO_INCREMENT ,
3`name`  varchar(255) NULL ,
4PRIMARY KEY (`id`)
5);
6
7INSERT INTO memeber VALUES(1,"jas")
复制代码
  1. 在mapper包中建立Memeber的mapper接口:
1public interface MemeberMapper {
2    /**
3     * 根据ID获取记录
4     * @param id
5     * @return
6     */

7    public Map findObjectById(Integer id);
8}
复制代码
  1. 在resource中的mapper文件夹建立memberMapper.xml,而且在mapper中增长一个findObjectById的SQL查询语句。
 1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE mapper
3        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
4        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

5<!--映射文件配置,namespace指向接口-->
6<mapper namespace="com.example.mybatisanddruid.mapper.MemeberMapper">
7#根据ID查询记录
8<select id="findObjectById" parameterType="Integer" resultType="Map">
9        select * from memeber where id = #{value}
10    </select>
11</mapper>
复制代码

5. hello world

走到这一步,基本上已是大功告成了,咱们来写一个测试类试试,在根目录建立一个controller的包,在包中建立一个Java类,以下:

 1@Controller
2@RequestMapping("/test")
3public class TestController {
4    @Resource
5    private MemeberMapper memeberMapper=null;
6
7    @RequestMapping("/one")
8    @ResponseBody
9    public Map testdb(){
10        return  memeberMapper.findObjectById(1);
11    }
12}
复制代码

建立完以后,咱们运行项目,找到启动类MybatisAndDruidApplication右键run,发现报错,提示没有扫描到mapper包,为何呢?那是mapper须要手动在启动类中加入:

1@MapperScan("com.example.mybatisanddruid.mapper")
复制代码

这样启动类就变成:

1@SpringBootApplication
2@MapperScan("com.example.mybatisanddruid.mapper")
3public class MybatisAndDruidApplication {
4
5    public static void main(String[] args) {
6        SpringApplication.run(MybatisAndDruidApplication.class, args);
7    }
8}
复制代码

再次运行,没有报错,在浏览器输入:http://localhost:8888/test/one
输出了ID为1的记录:

1{"name":"jas","id":1}
复制代码

因而可知,springboot-mybatis已经搭建成功,此时有人会问,那Druid呢?

  1. 设置Druid监控配置
    druid的使用须要作一些配置,如今咱们来在根目录下建立一个包config,在config包中间建立一个叫作DruidConfig.java,而且在里写入下面的内容:
 1@Configuration
2public class DruidConfig {
3    @Bean
4    public ServletRegistrationBean druidServlet() // 主要实现WEB监控的配置处理
5        ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new StatViewServlet(), "/druid/*"); // 进行druid监控的配置处理操做
6        servletRegistrationBean.addInitParameter("allow",
7                "127.0.0.1,192.168.1.159"); // 白名单
8        servletRegistrationBean.addInitParameter("deny""192.168.1.200"); // 黑名单
9        servletRegistrationBean.addInitParameter("loginUsername""stat"); // 用户名
10        servletRegistrationBean.addInitParameter("loginPassword""Wkt_sTat_1031"); // 密码
11        servletRegistrationBean.addInitParameter("resetEnable""false"); // 是否能够重置数据源
12        return servletRegistrationBean ;
13    }
14    @Bean
15    public FilterRegistrationBean filterRegistrationBean() {
16        FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean() ;
17        filterRegistrationBean.setFilter(new WebStatFilter());
18
19        filterRegistrationBean.addUrlPatterns("/*"); // 全部请求进行监控处理
20        filterRegistrationBean.addInitParameter("exclusions""*.js,*.gif,*.jpg,*.css,/druid/*");
21        return filterRegistrationBean ;
22    }
23    @Bean
24    @ConfigurationProperties(prefix = "spring.datasource")
25    public DataSource druidDataSource() {
26        return new DruidDataSource();
27    }
28
29}
复制代码

配置中的内容就不一一细讲, 有兴趣的直接百度一下druid就出来不少答案了,如今从新运行一下项目,运行成功以后,在浏览器中输入:http://localhost:8888/druid
这时候,druid监控平台就出现了

此时咱们输入在DruidConfig中设置的loginUsername和loginPassword点击登陆,一个完整的druid监控管理平台就呈如今咱们啦~

Druid很是强大,在这里你能够查看SQL的执行状况、慢SQL、API请求状况等,根据这些能够作一些性能的调优,至于详细的用法,就靠你们自行学习啦~

若是有老铁须要项目源码,请加我微信:sisi-ceo。


以为本文对你有帮助?请分享给更多人
关注「编程无界」,提高装逼技能

相关文章
相关标签/搜索
本站公众号
   欢迎关注本站公众号,获取更多信息