05-yaml给实体类赋值

本文介绍了如何在Spring Boot中使用@ConfigurationProperties从application.yaml配置文件为Java实体类如Dog和Person设置属性,并探讨了YAML作为首选配置方式的优劣。通过实例演示了如何装配配置和使用@Autowired自动注入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

yaml给实体类赋值

准备工作

pojo

Dog

//@Component为了更容易被扫描
@Component
public class Dog {
    private String name;
    private Integer age;
//有参无参 setter getter toString
}

Person

@Component
//@ConfigurationProperties(prefix = "person") 相当于绑定了application.yaml里面的person
//爆红的话得加个依赖
@ConfigurationProperties(prefix = "person")
public class Person {
    private String name;
    private Integer age;
    private Boolean happy;
    private Date Birthday;
    private Map<String,Object> maps;
    private List<Object> lists;
    private Dog dog;
    //有参无参 setter getter toString
}

application.yaml

person:
  name: 张三
  age: 3
  happy: false
  birthday: 2020/02/02
  maps: {k1,k2,k3}
  lists:
    - code
    - music
    - girl
  dog:
    name: 旺财
    age: 3

测试

package com.tian;

import com.tian.pojo.Dog;
import com.tian.pojo.Person;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.time.Period;

@SpringBootTest
class Springboot03ConfigApplicationTests {
    @Autowired
    //把狗装配过来了
    private Person person;

    @Test
    void contextLoads() {
        System.out.println(person);
    }

}

第二种方式(不建议使用)

1.先编写个自己的yaml 例如qinjiang.yaml

2.person类的修改

在这里插入图片描述

3.测试

扩展

在这里插入图片描述

firstName(pojo)和first-name(yml) 可以赋值

结论:

  • 配置yml和配置properties都可以获取到值,强烈推荐yml
  • 如果我们在某个业务中,只需要获取配置文件中的某个值,可以使用一下@value
  • 如果说,我们专门编写了一个JavaBean来和配置文件进行映射,就直接使用@configurationProperties,不要犹豫!
### 使用 MyBatis Plus 根据实体类自动生成数据库表结构配置教程 #### 一、引入依赖 为了使项目能够利用 MyBatis Plus 的功能,需在项目的 `pom.xml` 文件中加入相应的 Maven 依赖。 ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.2</version> </dependency> ``` 此操作确保了后续能调用到框架所提供的自动建表等特性[^1]。 #### 二、配置数据源与 MyBatis Plus 属性 编辑 application.yml 或者 application.properties 来设置连接至目标数据库的信息,并开启自动创建表格的功能: 对于 YAML 格式的文件来说, ```yaml spring: datasource: url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 driver-class-name: com.mysql.cj.jdbc.Driver username: root password: 123456 mybatis-plus: global-config: db-config: id-type: auto # 设置主键策略为自增型 table-auto-create: true # 开启自动创建表选项 ``` 上述配置项中的 `table-auto-create: true` 是关键所在,它指示当应用程序启动时如果发现不存在对应的表,则会依据已定义好的实体类来自行建立新表[^2]。 #### 三、编写实体类并标注映射关系 接下来就是按照实际需求来设计 Java Bean(即实体对象)。这里需要注意的是,在此类之上要加上特定的注解以便于 MyBatis Plus 能够识别出这是用来表示一张数据库表的数据模型。例如: ```java @Table(name="user") // 映射到名为 "user" 的数据库表 public class User { @TableId(type = IdType.AUTO) // 主键字段采用自增长方式赋值 private Long id; @TableField(value="username", exist=false) private String name; ... } ``` 通过以上步骤就可以让 Spring Boot 应用程序借助 MyBatis Plus 完成基于给定实体类的数据库表自动化构建过程了[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值