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;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/598416.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

语音识别之其他谱图

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

护眼灯有没有护眼的效果?一键查看这五大护眼效果极佳的护眼台灯

在数字时代&#xff0c;护眼灯已成为保护视力的重要工具。但消费者常问&#xff1a;护眼灯有没有护眼的效果&#xff1f;挑选到技术过关的护眼台灯是能够很好地起到护眼效果的。本文将并重点介绍五款具有卓越护眼功能的台灯。这些精选灯具不仅在照明效果上表现出色&#xff0c;…

leetcode-缺失的第一个正整数-96

题目要求 思路 1.这里的题目要求刚好符合map和unordered_map 2.创建一个对应map把元素添加进去&#xff0c;用map.find(res)进行查找&#xff0c;如果存在返回指向该元素的迭代器&#xff0c;否则返回map::end()。 代码实现 class Solution { public:int minNumberDisappeare…

智慧公厕打造智慧城市新标杆

公共厕所作为城市基础设施的重要组成部分&#xff0c;直接关系到市民的生活品质和城市形象。传统的公厕管理方式存在着许多问题&#xff0c;如环境脏乱、清洁不及时等&#xff0c;给市民带来了诸多不便和不满。而智慧公厕作为一种全新的管理模式&#xff0c;通过物联网、大数据…

Temporary Email邮箱API发送邮件怎么配置?

Temporary Email邮箱API发送邮件的方法&#xff1f;如何使用&#xff1f; 临时邮箱因其便捷性和隐私保护的优势&#xff0c;越来越受到用户的青睐。而在许多场景下&#xff0c;我们可能需要使用临时邮箱API来发送邮件。那么&#xff0c;如何配置Temporary Email邮箱API发送邮件…

Docker 操作redis

命令: docker删除容器命令:docker rm 容器名称 (默认只能删除停止运行的容器) 运行redis服务端并指定窗口: docker run --name mr -p 6379:6379 -d redis redis-server --appendonly yes 运行成功之后运行docker ps 可以查看运行中的所有容器以及状态 docke rexec -it mr b…

“A”分心得:我的云计算HCIE学习之路

大家好&#xff0c;我是誉天云计算HCIE周末班梁同学&#xff0c;在誉天老师和同学们的帮助下&#xff0c;我终于在4月24日顺利通过了云计算3.0 HCIE的认证考试&#xff0c;而且获得了A&#xff0c;这是让我特别惊喜的&#xff0c;功夫不负有心人。 我日常的工作是网络运维&…

nestjs 全栈进阶--自定义装饰器

视频教程 20_nest中自定义装饰器_哔哩哔哩_bilibili nest new custom-decorator -p pnpm pnpm start:dev 在Nestjs 中我们使用了大量装饰器 decorator &#xff0c;所以Nestjs 也允许我们去自定义装饰器。 1. 自定义方法装饰器 nest g decorator aaa --flat 它生产的代码…

基于web的物流管理系统

文章目录 项目介绍主要功能截图&#xff1a;部分代码展示设计总结项目获取方式 &#x1f345; 作者主页&#xff1a;超级无敌暴龙战士塔塔开 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 &…

操作系统实战(二)(linux+C语言)

实验内容 通过Linux 系统中管道通信机制&#xff0c;加深对于进程通信概念的理解&#xff0c;观察和体验并发进程间的通信和协作的效果 &#xff0c;练习利用无名管道进行进程通信的编程和调试技术。 管道pipe是进程间通信最基本的一种机制,两个进程可以通过管道一个在管道一…

618必买好物清单来袭,这些数码产品值得你考虑!

是不是很多朋友和我一样&#xff0c;已经迫不及待地为618好物节做好了准备&#xff0c;准备开启一场购物盛宴&#xff01;作为一名资深家居与数码爱好者&#xff0c;每年618好物节时我都会尽情挑选心仪的物品&#xff0c;因此今天我想和大家分享一下我的618购物清单&#xff0c…

不是,有你们这么卖东西的?涨价是肯定的,我苟住不浪也是必然的!——早读(逆天打工人爬取热门微信文章解读)

大家说我苟&#xff0c;我笑他人看不穿 引言Python 代码第一篇 洞见 晕船法则&#xff08;深度好文&#xff09;第二篇 九边 宅男之死结尾 理性的讨论能够促进理解 而不仅仅是赢得争论 我们追求的是通过讨论增进理解 而非仅仅证明自己的正确 引言 最近的言论似乎控制得更加严格…

LSS(Lift, Splat, Shoot)算法解析

1.简介 LSS(Lift, Splat, Shoot) 是一个比较经典的自下而上的构建BEV特征的3D目标检测算法&#xff0c;通过将图像特征反投影到3D空间生成伪视锥点云&#xff0c;通过Efficientnet算法提取云点的深度特征和图像特征并对深度信息进行估计&#xff0c;最终将点云特征转换到BEV空…

Minio(官方docker版)容器部署时区问题研究记录

文章目录 感慨&概述补充&#xff1a;MINIO_REGION和容器时间的关系 问题一&#xff1a;minio容器和本地容器时间不一致问题说明原因探究解决方法结果验证 问题二&#xff1a;minio修改时间和本地查询结果不一致具体问题原因探究解决办法时间转化工具类调用测试和验证上传文…

计算机组成结构—虚拟存储器

目录 一、虚拟存储器的基本概念 二、页式虚拟存储器 1.页表 2.快表(TLB) 3.具有 TLB 和 Cache 的多级存储系统 三、段式虚拟存储器 四、段页式虚拟存储器 五、虚拟存储器和Cache比较 早期的计算机&#xff0c;CPU 是直接操作主存的&#xff0c;也就是运行程序时&#xf…

深度学习之基于Vgg16卷积神经网络书法字体风格识别

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景 书法是中国传统文化的重要组成部分&#xff0c;具有深厚的历史底蕴和独特的艺术魅力。在数字化时代&…

第50期|GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区&#xff0c;集成了生成预训练Transformer&#xff08;GPT&#xff09;、人工智能生成内容&#xff08;AIGC&#xff09;以及大语言模型&#xff08;LLM&#xff09;等安全领域应用的知识。在这里&#xff0c;您可以找…

损失函数详解

1.损失函数 是一种衡量模型与数据吻合程度的算法。损失函数测量实际测量值和预测值之间差距的一种方式。损失函数的值越高预测就越错误&#xff0c;损失函数值越低则预测越接近真实值。对每个单独的观测(数据点)计算损失函数。将所有损失函数&#xff08;loss function&#xf…

Baidu Comate:你的智能编码助手,编程效率倍增的秘密武器

Baidu Comate智能编码助手 Baidu Comate 智能编码助手简单介绍安装使用查看Comate插件功能智能代码提示使用飞浆和百度智能小程序进行智能问答使用AutoWork插件实现二次函数图像的生成引用Comate知识库存在的问题结束语 Baidu Comate 智能编码助手简单介绍 Baidu Comate&#x…

设计模式(十一):外观模式

设计模式&#xff08;十一&#xff09;&#xff1a;外观模式 1. 外观模式的介绍2. 外观模式的类图3. 外观模式的实现3.1 创建一个接口3.2 创建接口的实现3.3 创建一个外观类3.4 测试 1. 外观模式的介绍 外观模式&#xff08;Facade Pattern&#xff09;属于结构型模式&#xf…
最新文章