当前位置: 首页 > news >正文

springboot中@Builder注解的详细用法实例,跟数据库结合。

在Spring Boot中,@Builder注解是Lombok库提供的一个注解,用于生成带有Builder模式支持的构造器方法。通过@Builder注解,可以简化对象的创建过程,特别适用于需要设置多个属性的情况。

下面是一个使用@Builder注解的示例:

java
Copy code
import lombok.Builder;
import lombok.Data;

@Data
@Builder
public class User {
    private Long id;
    private String username;
    private String password;
    private String email;
}
在上述示例中,我们使用@Data注解和@Builder注解来定义了一个名为User的类。@Data注解用于自动生成getter、setter、equals、hashCode等方法,而@Builder注解则为该类生成了带有Builder模式支持的构造器方法。

接下来,你可以将User类与数据库结合使用。以下是一个使用JPA和MySQL数据库的示例:

创建数据库表user:
sql
Copy code
CREATE TABLE user (
    id BIGINT PRIMARY KEY,
    username VARCHAR(255),
    password VARCHAR(255),
    email VARCHAR(255)
);
创建User实体类对应于数据库表:
java
Copy code
import lombok.*;

import javax.persistence.*;

@Entity
@Table(name = "user")
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String username;

    private String password;

    private String email;
}
在User类上使用了@Entity注解和JPA相关的注解,用于映射数据库表和实体类之间的关系。同时,还添加了@NoArgsConstructor和@AllArgsConstructor注解,用于生成无参构造器和全参构造器。

创建UserRepository接口来操作数据库:
java
Copy code
import org.springframework.data.jpa.repository.JpaRepository;

public interface UserRepository extends JpaRepository<User, Long> {
}
通过继承JpaRepository接口,可以获得许多常用的数据库操作方法,并且不需要自己编写SQL语句。

使用UserRepository进行数据库操作:
java
Copy code
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class UserService {
    private final UserRepository userRepository;

    public UserService(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    public List<User> getAllUsers() {
        return userRepository.findAll();
    }

    public void createUser(UserDto userDto) {
        User user = User.builder()
                .username(userDto.getUsername())
                .password(userDto.getPassword())
                .email(userDto.getEmail())
                .build();

        userRepository.save(user);
    }
}

在UserService中,我们注入了UserRepository,并使用@Builder注解创建了一个新的User对象。通过调用builder()方法,然后链式调用username()、password()和email()等方法来设置属性值,最后调用build()方法创建User对象。

在createUser()方法中,我们将UserDto作为参数传入,根据其中的数据使用@Builder注解创建一个新的User对象,并保存到数据库中。

这样,你就可以在Spring Boot中使用@Builder注解与数据库结合创建对象。请根据你的具体情况进行适当调整和扩展。

http://www.lryc.cn/news/253478.html

相关文章:

  • WT2605C蓝牙音频语音芯片:具备大功率IO驱动能力,引领音频技术新纪元
  • 【Java 基础】20 多线程操作方法
  • SpringBoot使用mybatis-plus分页查询无效解决方案
  • QT 中 线程池 (备查)
  • LeetCode刷题笔记第71题:简化路径
  • JavaScript <md5加密的两种不同输出结果分析>--案例(二点一)
  • 『亚马逊云科技产品测评』活动征文|基于亚马逊EC2云服务器配置Nginx静态网页
  • 28、卷积 - 卷积的基础公式
  • Mac电脑vm虚拟机 VMware Fusion Pro中文 for mac
  • 区块链技术的应用场景和优势
  • java面试题-谈谈sql优化-mysql
  • 【Linux服务器Java环境搭建】07 在linux中安装MySql,以及对MySQL的配置与远程连接
  • 用 LangChain 搭建基于 Notion 文档的 RAG 应用
  • QT中如何使用自定义控件
  • xcode ——Instrumets(网络连接调试)使用
  • Ps:文字操作常用快捷键
  • SpringSecurity的默认登录页的使用
  • 【Rust日报】2023-12-04 slint 成功案例
  • 嵌入式硬件和软件哪个好?
  • MySQL 8.x 自签证书通过keytool和openssl转成JKS文件
  • MybatisPlus概述
  • C++之枚举与宏定义
  • DAPP开发【09】NFT交易市场开发(hardhat测试)
  • 【Spring Boot】如何通过RestTemplate获取另一个服务的接口返回信息
  • 文字识别(OCR)专题——基于NCNN轻量级PaddleOCRv4模型C++推理
  • ❀My学习Linux命令小记录(14)❀
  • SqlServer存储过程中使用in
  • Selenium+Unittest+HTMLTestRunner框架更改为Selenium+Pytest+Allure(二)
  • Kotlin Lambda使用
  • 华容道问题求解第一部分_思路即方案设计