JPA Springboot 新东西

1.两个依赖

 <dependency>
            <groupId>io.hypersistence</groupId>
            <artifactId>hypersistence-utils-hibernate-63</artifactId>
            <version>3.7.3</version>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>8.0.1.Final</version>
        </dependency>

2.UUID主键

   @Id
    @GeneratedValue(generator = "my_uuid")
    @GenericGenerator(name = "my_uuid", type = UuidGenerator.class)
    @org.hibernate.annotations.UuidGenerator
    @Column(name = "id", columnDefinition = "varchar(55) comment '主键ID'")
    @Schema(description = "主键ID")
    private String id;

3.转JSON存数据库

  @Column(name = "dimensions", columnDefinition = "json  NOT NULL comment '维度集合json'")
    @Type(JsonType.class)
    @Schema(description = "维度集合json")
    private List<String> dimensions;

4.双主键

第一种

package com.tigeriot.reportconfiguration.biz.statisticsproperty.entity;


import io.hypersistence.utils.hibernate.type.json.JsonType;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.persistence.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import org.hibernate.annotations.CreationTimestamp;
import org.hibernate.annotations.Type;
import org.hibernate.annotations.UpdateTimestamp;

import java.io.Serializable;
import java.util.Date;
import java.util.List;

/**
 * 统计图表参数 表
 */
@Data
@Table(name = "statistics_property")
@Entity
@Accessors(chain = true)
@AllArgsConstructor
@NoArgsConstructor
public class StatisticsProperty {

    @EmbeddedId
    @Schema(description = "主键ID")
    private PK id;

    @Column(name = "cn_name", columnDefinition = "varchar(255) NOT NULL comment '中文名称'")
    @Schema(description = "中文名称")
    private String cnName;

//List<String>
    @Column(name = "dimensions", columnDefinition = "json  NOT NULL comment '维度集合json'")
    @Type(JsonType.class)
    @Schema(description = "维度集合json")
    private List<String> dimensions;


// [{"metric":"","method":"sum"},{}]
    @Column(name = "statistics", columnDefinition = "json  NOT NULL comment '统计值集合json'")
    @Type(JsonType.class)
    @Schema(description = "统计值集合json")
    private List<Statistics> statistics;


    @Column(name = "chart_style", columnDefinition = "varchar(255)  NOT NULL comment '图表样式 选择一个 样式: 饼图 柱状图'")
    @Schema(description = "图表样式 选择一个 样式: 饼图 柱状图")
    private String chartStyle;

    @Column(name = "create_user_id", columnDefinition = "varchar(255)  NOT NULL comment '创建用户ID'")
    @Schema(description = "创建用户ID")
    private String createUserId;

    @Column(name = "update_user_id", columnDefinition = "varchar(255)  NOT NULL comment '修改用户ID'")
    @Schema(description = "修改用户ID")
    private String updateUserId;

    @Column(name = "create_time", columnDefinition = "DateTime  NOT NULL comment '创建时间'")
    @Schema(description = "创建时间")
    @CreationTimestamp
    private Date createTime;

    @Column(name = "update_time", columnDefinition = "DateTime  NOT NULL comment '修改时间'")
    @Schema(description = "修改时间")
    @UpdateTimestamp
    private Date updateTime;



    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public static class Statistics{

        @Schema(description = "度量")
        private String metric;//度量
        @Schema(description = "算法")
        private String method;//算法
        @Schema(description = "度量分类")
        private String category;//度量分类

    }


    @Embeddable
    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public static class PK implements Serializable {
        @Column(name = "name",columnDefinition = "varchar(255) comment '统计图标参数主键名称' ")
        @Schema(description = "统计图标参数主键名称")
        private String name;
        @Column(name = "data_set_name",columnDefinition = "varchar(255) comment '数据集名称' ")
        @Schema(description = "数据集名称")
        private String dataSetName;
    }
}

第二种

package com.tigeriot.reportconfiguration.biz.dimensionoption.entity;

import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.persistence.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import org.hibernate.annotations.CreationTimestamp;
import org.hibernate.annotations.UpdateTimestamp;

import java.io.Serializable;
import java.util.Date;

@Data
@AllArgsConstructor
@NoArgsConstructor
@Accessors(chain = true)
@Entity
@Table(name = "dimension_option",schema = "维度选项")
@IdClass(DimensionOption.PK.class)
public class DimensionOption {

    @Id
    @Column(name = "dimension_name", columnDefinition = "varchar(55) comment '维度名称'")
    @Schema(description = "维度名称")
    private String dimensionName;

    @Column(name = "option_value", columnDefinition = "varchar(255) NOT NULL comment '维度值'")
    @Schema(description = "维度值")
    @Id
    private String optionValue;

    @Column(name = "option_text", columnDefinition = "varchar(255) NOT NULL comment '维度显示文本'")
    @Schema(description = "维度显示文本")
    private String optionText;

    @Column(name = "color", columnDefinition = "varchar(55) NOT NULL comment '选项颜色'")
    @Schema(description = "选项颜色")
    private String color;


    @Column(name = "order_weight", columnDefinition = "double NOT NULL comment '排序'")
    @Schema(description = "排序")
    private Double orderWeight;

    @Column(name = "create_user_id", columnDefinition = "varchar(255)  NOT NULL comment '创建用户ID'")
    @Schema(description = "创建用户ID")
    private String createUserId;

    @Column(name = "update_user_id", columnDefinition = "varchar(255)  NOT NULL comment '修改用户ID'")
    @Schema(description = "修改用户ID")
    private String updateUserId;

    @Column(name = "create_time", columnDefinition = "DateTime  NOT NULL comment '创建时间'")
    @Schema(description = "创建时间")
    @CreationTimestamp
    private Date createTime;

    @Column(name = "update_time", columnDefinition = "DateTime  NOT NULL comment '修改时间'")
    @Schema(description = "修改时间")
    @UpdateTimestamp
    private Date updateTime;


    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    @Accessors(chain = true)
    public static class PK implements Serializable {
        private String dimensionName;
        private String optionValue;
    }


}

5.加索引

package com.tigeriot.organization.api.organizationrelationheatstation.entity;

import com.tigeriot.organization.api.organizationtree.constant.OrganizationEnum;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.persistence.*;
import lombok.Data;
import org.hibernate.annotations.Comment;
import org.hibernate.annotations.CreationTimestamp;
import org.hibernate.annotations.GenericGenerator;
import org.hibernate.annotations.UpdateTimestamp;
import org.hibernate.id.uuid.UuidGenerator;

import java.util.Date;

@Data
@Entity
@Table(name = "organization_relation_heatStation", indexes = {
        @Index(name = "org_idx_company_id", columnList = "company_id"),
        @Index(name = "org_uni_heat_station_id", columnList = "heat_station_id", unique = true),
        @Index(name = "org_uni_parent_id_and_heat_station_id", columnList = "parent_id,heat_station_id", unique = true)
})
@Comment("组织与换热站关联中间表")
public class OrganizationRelationHeatStation {

    @Id
    @GeneratedValue(generator = "my_uuid")
    @GenericGenerator(name = "my_uuid", type = UuidGenerator.class)
    @org.hibernate.annotations.UuidGenerator
    @Column(name = "id", columnDefinition = "varchar(255) comment '主键ID'")
    @Schema(description = "主键ID")
    private String id;


    /**
     * 所属热力公司ID
     */
    @Column(name = "company_id", nullable = false)
    @Comment("所属热力公司ID")
    private String companyId;


    /**
     * 父节点ID
     */
    @Column(name = "parent_id", nullable = false)
    @Comment("父组织ID")
    private String parentId;

    /**
     * 换热站ID
     */
    @Column(name = "heat_station_id", nullable = false)
    @Comment("换热站ID")
    private String heatStationId;

    /**
     * 排序
     */
    @Column(name = "show_order", columnDefinition = "double NOT NULL")
    @Comment("排序")
    private Double showOrder;


    @Column(name = "create_user_id", columnDefinition = "varchar(255)  NOT NULL comment '创建用户ID'")
    @Schema(description = "创建用户ID")
    private String createUserId;

    @Column(name = "update_user_id", columnDefinition = "varchar(255)  NOT NULL comment '修改用户ID'")
    @Schema(description = "修改用户ID")
    private String updateUserId;

    @Column(name = "create_time", columnDefinition = "DateTime  NOT NULL comment '创建时间'")
    @Schema(description = "创建时间")
    @CreationTimestamp
    private Date createTime;

    @Column(name = "update_time", columnDefinition = "DateTime  NOT NULL comment '修改时间'")
    @Schema(description = "修改时间")
    @UpdateTimestamp
    private Date updateTime;


    public static OrganizationRelationHeatStation build(String companyId, String parentId, String heatStationId) {
        OrganizationRelationHeatStation organizationRelationHeatStation = new OrganizationRelationHeatStation();
        organizationRelationHeatStation.setHeatStationId(heatStationId);
        organizationRelationHeatStation.setParentId(parentId);
        organizationRelationHeatStation.setCompanyId(companyId);
        organizationRelationHeatStation.setShowOrder(0.0d);
        organizationRelationHeatStation.setCreateUserId(OrganizationEnum.userIdConst);
        organizationRelationHeatStation.setUpdateUserId(OrganizationEnum.userIdConst);
        return organizationRelationHeatStation;
    }
}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Hibernate Validator是一个用于Java Bean验证的框架,它提供了一组注解和API,用于验证Java Bean的属性值是否符合指定的规则和约束。它可以用于验证表单数据、REST API请求、数据库实体等各种场景下的数据。Hibernate Validator支持多种验证规则,包括基本数据类型、字符串、日期、集合、数组等。它还支持自定义验证规则和错误消息。使用Hibernate Validator可以有效地减少代码量和提高开发效率。 ### 回答2: Hibernate Validator是一个流行的Java开源校验框架,它是基于JSR 303规范(Bean验证)的实现。它提供了一组注释和API,用于对JavaBean进行验证和校验。 Hibernate Validator提供了很多内置的校验注释,比如@NotNull、@NotEmpty、@Min、@Max等。这些注释可以直接应用在JavaBean的属性上,通过注释指定的校验规则来验证属性的值是否合法。同时,Hibernate Validator还支持自定义校验注释,可以根据业务需求来定义的注释,并实现相应的校验逻辑。 Hibernate Validator不仅可以对单个属性进行校验,还支持对整个JavaBean进行校验。例如,可以在JavaBean的类级别上添加@Valid注释,来验证整个对象的合法性。此外,还可以通过分组校验来实现在不同场景下不同的校验规则。 除了注释方式外,Hibernate Validator还提供了一套强大的API,通过编程方式来进行校验和验证。通过ValidatorFactory和Validator两个主要的接口,可以创建Validator对象并执行校验操作。可以验证单个属性的值,也可以验证整个JavaBean对象。 Hibernate Validator还提供了国际化的支持,可以根据不同的区域设置显示不同的错误信息。同时,还能够将校验错误信息与具体的校验注释进行关联,方便开发者快速定位问题。 总结来说,Hibernate Validator提供了一种有效、灵活和方便的方式来对JavaBean进行校验。它的注释和API丰富多样,并且支持自定义校验规则,同时还提供了国际化和错误信息关联等特性,使得校验过程更加强大和可控。它在Java开发中的应用越来越广泛,为开发者提供了一种便捷的校验解决方案。 ### 回答3: Hibernate Validator是一个基于JSR 380规范的校验框架,它可以轻松地对Java对象进行校验。通过使用Hibernate Validator,开发人员可以在应用程序中方便地添加校验规则,并且可以验证这些规则是否被满足。 Hibernate Validator提供了一组注解,这些注解可以附加在JavaBean的属性上,以标识需要进行校验的规则。例如,@NotNull注解用于确保属性的值不为空,@Size注解用于确保字符串类型的属性的长度在指定范围内,等等。除了注解外,Hibernate Validator还提供了一些内置的校验器,用于验证各种数据类型的属性,例如字符串、数字、日期等。 使用Hibernate Validator进行校验非常简单。只需要在需要校验的JavaBean上添加注解,并在需要校验的时候调用校验方法即可。校验方法会返回一个包含校验结果的对象,开发人员可以根据需要进行处理。校验方法还可以接受一个可选的校验分组参数,用于校验不同场景下的不同规则。 Hibernate Validator还提供了一些扩展功能,用于自定义校验规则。开发人员可以创建自定义的校验注解,并编写相应的校验器来实现特定的校验逻辑。这使得Hibernate Validator非常灵活,可以满足各种不同的校验需求。 总结来说,Hibernate Validator是一个强大而灵活的校验框架,能够方便地对Java对象进行校验。使用Hibernate Validator可以增加应用程序的稳定性和可靠性,减少错误和异常的发生。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值