京淘day02-SpringBoot高级用法

  1. SpringBoot高级用法

1.1 关于配置文件说明

1.1.1 properties文件说明

1.语法: k-v结构 key=value
2.数据类型: 默认是String数据类型 不要添加多余的""号
3.字符数据类型: properties的默认的加载的编码格式为ISO-8859-1 所以添加中文是需要字符转意.
4.缺点: 所有的key都必须手动的编辑 没有办法复用 所以引入了yml配置

1.1.2 YML文件说明

#语法
# 1. 数据结构 key: value   使用:(空格)链接
# 2. YML文件中有文件父子级结构 采用缩进的方式实现.
server:
port: 8090

1.2 为属性赋值

1.2.1 业务需求

有时需要动态的获取属性的值,如果直接写到代码中需要重新打包编译,代码的耦合性较高.
能否利用配置文件的方式,动态的为属性赋值?

1.2.2 YML方式为属性赋值

1).编辑YML配置文件

#语法
# 1. 数据结构 key: value   使用:(空格)链接
# 2. YML文件中有文件父子级结构 采用缩进的方式实现.
server:
port: 8090

# 为Redis设定属性和属性值
redis.host: 127.0.0.1
redis.port: 6379

2).为属性赋值

package com.jt.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class RedisController {
/**
* 当程序启动时,会自动的加载YML配置文件,将数据保存到Spring的内部.
* 之后通过${key}(spel表达式)进行数据的取值.
*/
@Value("${redis.host}")
private String host;        // = "127.0.0.1";
@Value("${redis.port}")
private int port;           // = 6379;

@RequestMapping("/getNode")
public String getNode(){
return host + ":" + port;
}
}

1.2.3 指定配置文件为属性赋值

1).定义properties文件
京淘day02-SpringBoot高级用法_第1张图片
2).编辑RedisController

package com.jt.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
//指定配置文件进行加载
@PropertySource("classpath:/properties/redis.properties")
public class RedisController {
/**
* 当程序启动时,会自动的加载YML配置文件,将数据保存到Spring的内部.
* 之后通过${key}(spel表达式)进行数据的取值.
* 1.通过YML方式赋值
*/
@Value("${redis.host}")
private String host;        // = "127.0.0.1";
@Value("${redis.port}")
private int port;           // = 6379;

//2.通过pro方式赋值
@Value("${redis2.host}")
private String host2;
@Value("${redis2.port}")
private int port2;

@RequestMapping("/getNode")
public String getNode(){
return "YML取值方式"+host + ":" + port+"| " +
"pro取值方式:"+host2+":"+port2;
}
}

1.2.4 如果YML和Properties属性重名以谁为准?

答: YML方式为准, 注意事项:属性最好不要重复.

1.3 环境切换

1.3.1 业务需求

如果小李进入外包公司,需要频繁切换不同的工作地点.由于公司的环境配置非常繁琐,每次切换小李都需要修改大量的配置文件,问: 能否优化?

1.3.1 实现多环境配置

#挑选执行环境   SpringCloud微服务配置 N多个YML配置文件 配置中心
spring:
profiles:
active : test

---   #环境分割线
#语法
# 1. 数据结构 key: value   使用:(空格)链接
# 2. YML文件中有文件父子级结构 采用缩进的方式实现.

#定义环境名称   2.4.0版本需要如下的格式
spring:
config:
activate:
on-profile: test

server:
port: 8090

# 为Redis设定属性和属性值
redis.host: 127.0.0.1
redis.port: 6379

# 通过---方式实现YML环境的分割
---
spring:
profiles: prod   #2.4.0以下的写法

server:
port: 9000

# 为Redis设定属性和属性值
redis.host: 192.168.1.1
redis.port: 7000

1.4 热部署配置

弊端: IDEA启动时特别耗费内存,如果配置了热部署,则卡上加卡

1.4.1 添加jar包



org.springframework.boot
spring-boot-devtools

1.4.2 IDEA配置

组合键: ctrl + alt+shift + /

1.5 关于LOMBOK复习

1.5.1 添加jar包



org.projectlombok
lombok

1.5.3 面试问题

问:如果项目需要在Linux系统中运行,问系统是否需要提前安装LomBok插件?
A.需要 B.不需要
答案: B 不需要
原因: LOMBOK插件在编译期有效. 由.java文件编译为.class文件时生效.
京淘day02-SpringBoot高级用法_第2张图片

1.5 SpringBoot整合Mybatis

1.5.1 导入jar包



mysql
mysql-connector-java




org.springframework.boot
spring-boot-starter-jdbc




org.mybatis.spring.boot
mybatis-spring-boot-starter
2.1.3

1.5.2 创建pojo

package com.jt.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data //get/set/toString(只能打印自己的属性,不能输出父类的属性,如想获取通过getXX方法获取)/equals等方法
@NoArgsConstructor //无参构造
@AllArgsConstructor //全参构造
public class User{
    //POJO实体对象中属性类型必须使用包装类型
 private Integer id;
 private String name;
 private Integer age;
 private String sex;
 }

1.5.3 创建mapper接口

package com.jt.mapper;
importcom.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.jt.pojo.User;
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
@Mapper //将mapper接口交给Spring容器管理.并且为其创建代理对象 CGLIB代理方式
public interface UserMapper{
    //查询数据库中所有的用户数据
 //@Select("select * from user")
 List findAll();
}

1.5.4 编辑YML配置文件

1).关于URL说明
serverTimezone=GMT%2B8& %2B=+ 设定时区
useUnicode=true&characterEncoding=utf8& 设定字符集编码格式
autoReconnect=true& 如果链接中断是否自动重连
allowMultiQueries=true 是否允许批量操作.
2).YML文件配置

server:
port: 8090
servlet:
context-path: /     #项目根目录发布
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/jtdb?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
username: root
password: root

# Spring整合Mybatis配置
mybatis:
type-aliases-package: com.jt.pojo
mapper-locations: classpath:/mybatis/mappers/*.xml
#开启驼峰映射
configuration:
map-underscore-to-camel-case: true

1.5.6 编辑Mapper.xml配置文件










1.5.6 入门案例测试

package com.jt;
import com.jt.mapper.UserMapper;
import com.jt.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.List;
@SpringBootTest //写测试类时如果需要从容器中动态的获取对象时使用
class SpringbootDemo2ApplicationTests {
@Autowired
private UserMapper userMapper;
@Test
public void testMybatis01(){
List userList = userMapper.findAll();
System.out.println(userList);
}
}

2.MybatisPlus

2.1 ORM思想介绍

对象关系映射(英语:Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”。如今已有很多免费和付费的ORM产品,而有些程序员更倾向于创建自己的ORM工具。
核心: 采用对象的方式操作数据库.
思考:
userMapper.insert(user对象) ~剩余的入库sql由框架自动完成!!!

2.2 MybatisPlus介绍

2.2.1 介绍

MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

特性

无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作
强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求
支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错
支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题
支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作
支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )
内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用
内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询
分页插件支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库
内置性能分析插件:可输出 Sql 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作

2.2.2 引入jar包



com.baomidou
mybatis-plus-boot-starter
3.2.0

2.2.3 编辑POJO对象

2.2.4 Mapper接口继承

2.2.5 修改YML配置

server:
port: 8090
servlet:
context-path: /                     #项目根目录发布
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/jtdb?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true
username: root
password: root

# Spring整合Mybatis-plus配置
mybatis-plus:
type-aliases-package: com.jt.pojo
mapper-locations: classpath:/mybatis/mappers/*.xml
#开启驼峰映射
configuration:
map-underscore-to-camel-case: true

2.2.6 入门案例测试

2.3MybatisPlus工作原理

ORM: 以对象的方式操作数据表
Sql:

  1. 数据库只能识别Sql语句. 不能识别对象
  2. 如果每天都写特别简单的Sql 没有任何价值.

核心原理:

  1. 利用注解去标识对象与表的映射关系 @TableName(“表名称”) 字段与属性的映射
  2. 将公共的接口方法进行抽取,抽取到公共接口中,如果需要使用只需继承即可. 注意事项:
  3. 操作对象时需要有专门的API实现对象与Sql的转化.最终交给Mybatis去执行.

例子: userMapper.insert(user对象)
Sql : insert into 表名(字段1,字段2,字段3…) values(值1,值2,值3…)

2.4 MybatisPlus入门案例

2.4.1 添加日志打印

2.4.2 入门案例

package com.jt;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.jt.mapper.UserMapper;
import com.jt.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
@SpringBootTest //写测试类时如果需要从容器中动态的获取对象时使用
class Demo02ApplicationTests {
   @Autowired
 private UserMapper userMapper;
   @Test
 public void testMybatis01() {
      List userList = userMapper.findAll();
      System.out.println(userList);
   }
   @Test
 public void testSelectList() {
      //查询所有数据
 List userList = userMapper.selectList(null);
      System.out.println(userList);
   }
   /**
 * 1.查询用户数据,根据id=51号数据
 * Sql: select * from user where id=51
 */ @Test
 public void select01(){
      User user = userMapper.selectById(51) ; //根据主键查询
 System.out.println(user);
   }
   /**
 * 2. name="王昭君"的用户
 * Sql: select * from user where name="xxx"
 * 条件构造器:主要作用动态拼接where条件的
 * 特殊符号:
 *     1.=eq, 2.>gt, 3.= ge 5.<=le
 */ @Test
 public void select02(){
      QueryWrapper queryWrapper = new QueryWrapper<>();
      queryWrapper.eq("name", "王昭君");
      List userList = userMapper.selectList(queryWrapper);
      System.out.println(userList);
   }
   /**
 * 查询性别为男性,要求按照年龄降序排列
 * Sql: select * from user where sex="男" order by age desc
 */ @Test
 public void select03(){
      QueryWrapper queryWrapper = new QueryWrapper<>();
      queryWrapper.eq("sex", "男").orderByDesc("age");
      List userList = userMapper.selectList(queryWrapper);
      System.out.println(userList);
   }
   /**
 * 查询name中包含 "精"用户,按照年龄升序排序
 * Sql: select * from user where name like "%精%" "%精" "精%" order by age asc
 */ @Test
 public void select04(){
      QueryWrapper queryWrapper = new QueryWrapper<>();
      queryWrapper.like("name", "精").orderByAsc("age");
      List userList = userMapper.selectList(queryWrapper);
      System.out.println(userList);
   }
   /**
 * 查询age>=18 and age<100 and sex=男
 */
 @Test
 public void select05(){
      QueryWrapper queryWrapper = new QueryWrapper<>();
      queryWrapper.between("age", 18, 100).eq("sex", "男");
      //queryWrapper.ge("age", 18).lt("age", 100).eq("sex", "男");
 List userList = userMapper.selectList(queryWrapper);
      System.out.println(userList);
   }
   /**
 *查询id=1,3,5,6,7的用户
 * 查询name=“黑熊精、白龙驴、大乔”
 */ @Test
 public void select06(){
      Integer[] ids={1,3,5,6,7};
      List idList= Arrays.asList(ids);
      List userList=userMapper.selectBatchIds(idList);
      System.out.println(userList);
      QueryWrapper queryWrapper=new QueryWrapper();
      queryWrapper.in("name", "黑熊精","白龙驴","大乔");
      List userList1=userMapper.selectList(queryWrapper);
      System.out.println(userList1);
   }
   /**
 * 查询 id,name 全部用户信息
 */
 @Test
 public void select07(){
      QueryWrapper queryWrapper = new QueryWrapper<>();
      queryWrapper.select("id","name");
      List userList = userMapper.selectList(queryWrapper);
      System.out.println(userList);
      List> userMap = userMapper.selectMaps(queryWrapper);
      System.out.println(userMap);
   }
   @Test
 public void insert(){
      User user = new User();
      user.setId(null).setName("嫦娥5号").setAge(5).setSex("女");
      userMapper.insert(user);
   }
}

你可能感兴趣的:(springboot)