注:日常学习记录贴,下面描述的有误解的话请指出,大家一同学习。

因为我公司现在用的是postgresql数据库,所以我也用postgresql进行测试

一、前言

1.Spring boot 会默认读取src/main/resource路径下的application.properties(或者application.yml)文件的内容,一般自定义的配置文件也位于此目录之下。

2配置文件会自动加载,意思就是将文件读取到Spring容器之中,更确切的说就是将各个配置项装载到Spring上下文容器之中供随时取用。

  application.properties配置文件是在SpringBoot项目启动的时候被自动加载的,其内部的相关设置会自动覆盖SpringBoot默认的对应设置项,所以的配置项均会保存到Spring容器之中。

二、数据库

1.创建db:springbootDemo

2.创建schema:db_user

3.创建表和数据

CREATE TABLE "db_user"."t_user" (
        "id" varchar(32) COLLATE "default" NOT NULL,
        "name" varchar(255) COLLATE "default",
        "password" varchar(255) COLLATE "default",
        CONSTRAINT "t_user_pkey" PRIMARY KEY ("id")
      )
    WITH (OIDS=FALSE);

INSERT INTO "db_user"."t_user" VALUES ('1', 'admin', '123456');
    INSERT INTO "db_user"."t_user" VALUES ('2', 'admin2', 'admin212');

三、项目结构

1.application.properties

#设置Tomcat端口,默认8080
server.port=8080
#设置项目ContextPath
server.context-path=/
#设置Tomcat编码
server.tomcat.uri-encoding=UTF-8
#设置视图解析器路径
spring.mvc.view.prefix=/webapp/views/
#设置视图解析器后缀
spring.mvc.view.suffix=.jsp
#开发时关闭缓存,不然没法看到实时页面
spring.thymeleaf.cache=false

#数据库配置
spring.datasource.driver-class-name=org.postgresql.Driver
spring.datasource.url=jdbc:postgresql://[你的ip]:5432/springbootDemo?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true&currentSchema=db_user
spring.datasource.username=[用户名]
spring.datasource.password=[密码]

#连接池配置
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxActive=20
#连接等待超时时间
spring.datasource.maxWait=60000
#配置隔多久进行一次检测(检测可以关闭的空闲连接)
spring.datasource.timeBetweenEvictionRunsMillis=60000
#配置连接在池中的最小生存时间
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.validationQuery=SELECT 1 FROM DUAL
spring.datasource.testWhileIdle=true
spring.datasource.testOnBorrow=false
spring.datasource.testOnReturn=false
# 打开PSCache,并且指定每个连接上PSCache的大小
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙
spring.datasource.filters=stat,wall,log4j
# 通过connectProperties属性来打开mergeSql功能;慢SQL记录
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

#配置.xml文件路径
mybatis.config-locations=classpath:mybatis/mybatis-config.xml
mybatis.mapper-locations=classpath:/com/yang/springbootDemo/mapper/*.xml
#配置模型路径
mybatis.type-aliases-package=com.yang.springbootDemo.model

2.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>
    <settings>
        <setting name="callSettersOnNulls" value="true"/>
        
        <setting name="cacheEnabled" value="true"/>
        
        <setting name="lazyLoadingEnabled" value="true"/>
        
        <setting name="aggressiveLazyLoading" value="true"/>
        
        <setting name="multipleResultSetsEnabled" value="true"/>
        
        <setting name="useColumnLabel" value="true"/>
        
        <setting name="useGeneratedKeys" value="false"/>
        
        <setting name="autoMappingBehavior" value="PARTIAL"/>
        
        <setting name="defaultExecutorType" value="SIMPLE"/>
        
        <setting name="mapUnderscoreToCamelCase" value="true"/>
        
        <setting name="localCacheScope" value="SESSION"/>
        
        <setting name="jdbcTypeForNull" value="NULL"/>
        
    </settings>
 
    <typeAliases>
        <typeAlias alias="Integer" type="java.lang.Integer" />
        <typeAlias alias="Long" type="java.lang.Long" />
        <typeAlias alias="HashMap" type="java.util.HashMap" />
        <typeAlias alias="LinkedHashMap" type="java.util.LinkedHashMap" />
        <typeAlias alias="ArrayList" type="java.util.ArrayList" />
        <typeAlias alias="LinkedList" type="java.util.LinkedList" />
    </typeAliases>
</configuration>

3、ApplicationMain.java 启动类

package com.yang.springbootDemo.controller;

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

/**
 * spring boot启动类
 * @author liuyang
 *
 * 2018年8月3日 下午4:15:20
 */
@SpringBootApplication
@MapperScan("com.yang.springbootDemo.dao")
public class ApplicationMain extends SpringBootServletInitializer{

public static void main(String[] args) throws Exception {
        SpringApplication.run(ApplicationMain.class, args);
    }

}

4、UserController.java

package com.yang.springbootDemo.controller;

import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import com.yang.springbootDemo.dao.UserMapper;
import com.yang.springbootDemo.entity.UserEntity;

@Controller
@SpringBootApplication
@RequestMapping("user/")
public class UserController {

@Autowired
    private UserMapper userMapper;
    
    @RequestMapping("getUser")
    @ResponseBody
    public Object getUser(String name){
        UserEntity user =null;
        if(StringUtils.isNotBlank(name)){
            user = userMapper.getUser(name);
        }
        return user;
    } 
}

5、UserMapper.java

package com.yang.springbootDemo.dao;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import com.yang.springbootDemo.entity.UserEntity;

@Mapper
public interface UserMapper {
    
  UserEntity getUser(@Param("name") String name);
}

6、UserEntity.java

package com.yang.springbootDemo.entity;

public class UserEntity {
    private String name;
    private String password;

public String getName() {
        return name;
    }

public void setName(String name) {
        this.name = name;
    }

public String getPassword() {
        return password;
    }

public void setPassword(String password) {
        this.password = password;
    }
}

7、userMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.yang.springbootDemo.dao.UserMapper">
 
 <select id="getUser" parameterType="string" resultType="com.yang.springbootDemo.entity.UserEntity">
   select name,password  from t_user 
      where   name = #{name}
 </select>

</mapper>

8、pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.yang</groupId>
    <artifactId>springbootDemo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>war</packaging>

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.6.RELEASE</version>
    </parent>
    <dependencies>

<dependency>
            <groupId>postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>9.4.1207-atlassian-hosted</version>
        </dependency>

<dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.0</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.apache.tomcat</groupId>
                    <artifactId>tomcat-jdbc</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <!-- 移除嵌入式tomcat插件 -->
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

<!-- 热部署 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
            <scope>true</scope>
        </dependency>

<dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
            <scope>provided</scope>
        </dependency>

<!-- junit依赖 -->
        <!-- <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> 
            <version> 1.5.6.RELEASE</version> </dependency> -->
        <!-- <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> 
            <version>4.3.10.RELEASE</version> </dependency> -->
        <!-- <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> 
            <version> 4.12</version> </dependency> -->

<dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.datatype</groupId>
            <artifactId>jackson-datatype-joda</artifactId>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.module</groupId>
            <artifactId>jackson-module-parameter-names</artifactId>
        </dependency>
        <!-- 分页插件 -->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper-spring-boot-starter</artifactId>
            <version>1.1.2</version>
        </dependency>
        <!-- alibaba的druid数据库连接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.0</version>
        </dependency>
        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.3</version>
        </dependency>

</dependencies>

<build>
        <finalName>bootDemo</finalName>
        <!-- <sourceDirectory>${basedir}/src/main/java/</sourceDirectory> <outputDirectory>${basedir}/web/WEB-INF/classes</outputDirectory> 
            <resources> <resource> <directory>${basedir}/src</directory> <excludes> <exclude>**/*.java</exclude> 
            </excludes> </resource> </resources> -->

<plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <!-- 没有该配置,devtools 不生效 -->
                    <fork>true</fork>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

四、tomcat启动

五、调用接口

转载于:https://www.cnblogs.com/telwanggs/p/10786302.html

spring boot +mybatis(通过properties配置) 集成相关推荐

  1. spring boot mybatis 日志打印配置

    关于springboot日志配置的文章挺多的在此不做赘述,可参考博客: http://tengj.top/2017/04/05/springboot7/ 这里我要说的是关于日志打印等级过滤.sql打印 ...

  2. Spring Boot+Mybatis:实现数据库登录注册与两种properties配置参数读取

    〇.参考资料 1.hutool介绍 https://blog.csdn.net/abst122/article/details/124091375 2.Spring Boot+Mybatis实现登录注 ...

  3. java spring sqlite,Spring Boot+MyBatis+SQLite配置

    Spring Boot+MyBatis+SQLite配置例子参考下面 创建新项目 项目类型务必选择箭头指定的类型,否则不会自动生成代码模版 增加依赖项 junit junit 4.13.1 test ...

  4. Spring Boot + Mybatis 配合 AOP 和注解实现动态数据源切换配置

    Spring Boot + Mybatis 配合 AOP 和注解实现动态数据源切换配置 前言: 1. 数据库准备: 2. 环境准备: 3.代码部分 4. 测试: 5.等等 6.配合注解实现 7 .测试 ...

  5. spring boot+mybatis整合

    LZ今天自己搭建了下Spring boot+Mybatis,比原来的Spring+SpringMVC+Mybatis简单好多.其实只用Spring boot也可以开发,但是对于多表多条件分页查询,Sp ...

  6. Spring Boot + Mybatis 实现动态数据源

    动态数据源 在很多具体应用场景的时候,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库.又比如业务A要访问A数据库,业务B要访问B数据库等,都可以使用动 ...

  7. Spring boot Mybatis 整合(注解版)

    之前写过一篇关于springboot 与 mybatis整合的博文,使用了一段时间spring-data-jpa,发现那种方式真的是太爽了,mybatis的xml的映射配置总觉得有点麻烦.接口定义和映 ...

  8. Spring Boot MyBatis

    MyBatis简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache 迁移到了google code,并且改名为MyBatis . 集成spring bo ...

  9. spring boot + mybatis + layui + shiro后台权限管理系统

    后台管理系统 版本更新 后续版本更新内容 链接入口: springboot + shiro之登录人数限制.登录判断重定向.session时间设置:https://blog.51cto.com/wyai ...

最新文章

  1. 007-迅雷定时重启AutoHotkey脚本-20190411
  2. JAVA——一次性读取或者写入文本文件所有内容
  3. lisp求面与面的差集_AcGeVector3d是点阵的集合,通过等分点的差集得到。 新的点可以通过点与点阵相差得......
  4. Qt之QThreadPool和QRunnable
  5. 带栩字的优美古诗句_带栩字的名字_以栩字起名-尚名网
  6. 关于Spring的几个问题
  7. 玩转Linux进程控制命令
  8. 数值分析matlab实验报告,数值分析第一次作业matlab实验报告.doc
  9. mysql性能优化金字塔法则 下载_千金良方:MySQL性能优化金字塔法则 pdf版
  10. 英特尔服务器主板型号参数对照表,intel主板_目前市场上intel主板芯片组型号对应cpu针脚数量?...
  11. 28Python库分析科比生涯数据
  12. 复印机扫描仪错误怎么回事_打印机扫描后出现错误怎么处理?
  13. tenacity发生异常/失败/错误时重试retry机制,Python
  14. 前后端分离之使用Files进行文件图片上传和下载
  15. 小米笔记本 air 12.5寸 支持硬盘参数
  16. Finereport 9.0升级到10.0工具下载[9-10升级工具]
  17. 微信小程序开发:实现高斯模糊效果(毛玻璃效果)
  18. C#开发BIMFACE系列19 服务端API之获取模型数据4:获取多个构件的共同属性
  19. Ext.grid.EditorGridPanel viewConfig 设置表格 UniDBGrid
  20. WebLogic JVM Core dumps文件的生成控制

热门文章

  1. 山西职业技术学院计算机宿舍怎么样,山西职业技术学院宿舍怎么样
  2. 注解返回html页面,【提问】ajax请求返回整个html页面
  3. (116)FPGA面试题-FIFO相关参数与信号,为什么要用格雷码
  4. (67)Verilog HDL模块条件例化
  5. (18)FPGA面试题查找表的原理与结构
  6. python经典程序实例_Python入门经典实例(一)
  7. 7004.vue脚手架快速生成项目
  8. 【K210】【MaixPy】三、Maix Dock入门之LCD的使用(播放BadApple)
  9. 【蓝桥杯单片机】定时器和中断
  10. java 集合操作工具包_java之操作集合的工具类--Collections