【SpringBoot_ANNOTATIONS】属性赋值 01 @Value赋值

本文对比了传统XML配置与Java注解方式在设置Person类属性值上的区别,包括使用`@Value`注解的灵活性和Spring配置文件person.properties的应用。展示了如何通过配置文件动态赋值并测试两种方法的实际效果。

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

属性赋值 01 @Value赋值

传统方式

public class Person {
    private String name;
    private Integer age;
    private String nickName;

    public Person() {
    }

    public Person(String name, Integer age, String nickName) {
        this.name = name;
        this.age = age;
        this.nickName = nickName;
    }

    public String getName() {
        return name;
    }

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

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getNickName() {
        return nickName;
    }

    public void setNickName(String nickName) {
        this.nickName = nickName;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", nickName='" + nickName + '\'' +
                '}';
    }
}

beans.xml

    <context:property-placeholder location="classpath:person.properties" />
    <bean id="person4PropertyValues" class="com.example.annotations.bean.Person">
        <property name="age" value="21"/>
        <property name="name" value="qd"/>
        <property name="nickName" value="${person.nickName}"/>
    </bean>

在这里插入图片描述

配置文件
person.properties

person.nickName=Aimer

测试

    @Test
    void xmlPropertyValuesTest(){
        //传统方式
        ClassPathXmlApplicationContext xmlApplicationContext = new ClassPathXmlApplicationContext("beans.xml");
        System.out.println("容器创建完毕");
        //获取bean
        System.out.println("准备获取bean");
        Object person4PropertyValues = xmlApplicationContext.getBean("person4PropertyValues");
        System.out.println(person4PropertyValues.toString());
        System.out.println("获取完毕");
        //关闭容器
        xmlApplicationContext.close();
        System.out.println("容器已关闭");
    }

运行结果:
在这里插入图片描述

注解方式

  1. 基本数值
  2. SPEL表达式 : #{22-1} => 21
  3. ${} :取出配置文件的值 [在运行环境变量中的值]

Person.java

public class Person {
    @Value("qd")
    private String name;
    @Value("#{22-1}")
    private Integer age;

    public Person() {
    }

    public Person(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

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

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getNickName() {
        return nickName;
    }

    public void setNickName(String nickName) {
        this.nickName = nickName;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

配置类

@Configuration
public class MainConfig4PropertyValues {
    @Bean("person4PropertyValues")
    public Person person(){
        return new Person();
    }
}

测试

    @Test
    void propertyValuesTest(){
        //配置类测试
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainConfig4PropertyValues.class);
        System.out.println("容器创建完毕");
        //获取bean
        System.out.println("准备获取bean");
        Object person4PropertyValues = applicationContext.getBean("person4PropertyValues");
        System.out.println(person4PropertyValues.toString());
        System.out.println("获取完毕");
        //关闭容器
        applicationContext.close();
        System.out.println("容器已关闭");
    }

运行结果
在这里插入图片描述

注意 无论是beans.xml 还是配置类 都要保证bean的名字不重复

### MyBatisPlus 实现插入数据后返回主键值的功能 在 Oracle 数据库中,由于其本身不支持自增主键特性,因此需要通过创建序列来模拟主键自增的效果。以下是基于 SpringBoot 和 MyBatisPlus 的配置示例以及实现方法。 #### 1. 创建 Oracle 序列 为了实现主键自增,在数据库层面需先定义一个序列对象。可以通过以下 SQL 脚本完成: ```sql CREATE SEQUENCE seq_id MINVALUE 1 MAXVALUE 999999999999999999999999999 START WITH 1 INCREMENT BY 1 CACHE 20; ``` 上述语句会创建名为 `seq_id` 的序列[^1]。 --- #### 2. 配置实体类 在实体类中标记主键字段并指定生成策略为 `AUTO` 或者 `ASSIGN_ID`,同时设置对应的注解属性如下所示: ```java import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableName; @TableName("your_table_name") // 替换为实际表名 public class YourEntity { @TableId(type = IdType.INPUT) // 使用 INPUT 类型表示手动赋值 private Long id; // 对应的主键字段 // Getter and Setter 方法省略... } ``` 注意这里使用的是 `IdType.INPUT`,因为我们将依赖于 Oracle 中预先设定好的序列来自动生成 ID 值。 --- #### 3. 设置全局配置文件 (application.yml) 确保项目中的 application.yml 文件包含了必要的 mybatis-plus 参数调整,特别是 key-generator 属性部分: ```yaml mybatis-plus: global-config: db-config: id-type: auto # 可选,默认即可满足需求 key-generator: com.baomidou.mybatisplus.incrementer.OracleKeyGenerator ``` 其中指定了用于处理 oracle 数据源环境下的 Key Generator 工具类路径[^2]。 --- #### 4. Mapper 接口编写 当采用 tk.mybatis.mapper.common.Mapper 方式开发时需要注意覆盖默认行为或者重新定义 insert 方法逻辑以便兼容插件机制: ```java import org.apache.ibatis.annotations.InsertProvider; import tk.mybatis.mapper.common.Mapper; public interface YourMapper extends Mapper<YourEntity> { @InsertProvider(type=SqlProvider.class, method="dynamicSQL") int insertWithGeneratedKeys(@Param("record") YourEntity record); } // SqlProvider.java 提供动态 sql 支持 class SqlProvider{ public String dynamicSQL(){ return "INSERT INTO your_table_name(id,...other_columns...) VALUES(seq_id.nextval,...)"; } } ``` 以上代码片段展示了如何扩展标准接口以适应特定场景的需求[^3]。 --- #### 完整流程总结 综上所述,要让 MyBatis Plus 在操作 Oracle 表格记录的同时能够自动获取新产生的唯一标识符作为返回结果,则需要经历以下几个环节的操作: - **建立专用 Sequence**; - **修改 Entity Bean 注解声明方式**; - **更新 Application Properties/Yml 设定项**; - (可选项)针对特殊业务定制化 Insert 功能[^4]。 最终达成效果即每当新增一条记录之后都会同步反馈该条目所关联的新鲜出炉的 Primary Key Value 给调用方程序知晓。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值