如何设计和实现通用唯一 Code 生成方法

在开发中,尤其是涉及分层结构(如分类、目录、组织等)时,唯一的编码(Code)是一个常见需求。一个好的编码生成器需要确保代码的唯一性、可读性,并且能够随着层级的递增动态扩展。本文将探讨如何设计和实现一个通用的唯一 Code 生成方法。


场景分析
  1. 需求

    • 第一层的编码规则是 B+两位数字(如 B01)。
    • 第二层是 B+三位数字(如 B01001),第三层以此类推。
    • 编码需唯一,并支持动态生成。
    • 子层级的编码需基于父层级的编码(如 B01 的子级为 B01001)。
  2. 常见的应用场景

    • 组织架构:如公司 -> 部门 -> 团队。
    • 商品分类:如一级分类 -> 二级分类 -> 三级分类。
    • 文件目录:如文件夹 -> 子文件夹 -> 文件。

设计要点
  1. 唯一性

    • 每个编码在其所属层级内必须唯一。
    • 子层级编码必须包含父层级的编码。
  2. 动态扩展性

    • 层级数不固定,可根据需要自由扩展。
  3. 高效查询

    • 生成编码时,应尽量减少对数据库的读写操作,提高性能。
  4. 清晰的规则

    • 规则简单明了,便于开发和维护。
    • 不允许有模糊的特殊字符或冗余的空格。

实现思路
  1. 规则定义

    • 第一层:以 B 开头,后接两位数字(B01)。
    • 第二层:在父级编码基础上追加三位数字(B01001)。
    • 第三层:继续追加三位数字(B01001001)。
  2. 递增逻辑

    • 查询当前层级的最大编码。
    • 在最大编码的末尾递增(如 001 -> 002)。
  3. 默认值生成

    • 如果层级中无记录,则从 B01001 开始生成。
  4. 数据存储

    • 数据表需包含以下字段:
      • Code(编码)
      • Level(层级)
      • Pid(父节点 ID,用于关联父层级)
      • Name(名称,用于展示)

代码实现

以下是使用 C# 的实现示例:

数据库服务层
public async Task<string> GetMaxCodeByLevelAsync(int level, Guid? parentId = null)
{
    if (parentId.HasValue)
    {
        // 查询特定父节点下的最大 Code
        return await _context.SpAdjustmentDicts
            .Where(o => o.Level == level && o.Pid == parentId)
            .OrderByDescending(o => o.Code)
            .Select(o => o.Code)
            .FirstOrDefaultAsync();
    }
    else
    {
        // 查询该层级的最大 Code
        return await _context.SpAdjustmentDicts
            .Where(o => o.Level == level)
            .OrderByDescending(o => o.Code)
            .Select(o => o.Code)
            .FirstOrDefaultAsync();
    }
}
生成编码方法
private async Task<string> GenerateCodeAsync(int level, Guid? parentId = null)
{
    string maxCode = await GetMaxCodeByLevelAsync(level, parentId);

    if (string.IsNullOrEmpty(maxCode))
    {
        if (parentId.HasValue)
        {
            // 子层级的默认起始值
            var parent = await _context.SpAdjustmentDicts.FindAsync(parentId);
            return parent.Code + "001";
        }
        else
        {
            // 第一层默认值
            return "B01";
        }
    }

    // 递增逻辑
    if (parentId.HasValue)
    {
        // 子层级递增
        int subNumber = int.Parse(maxCode.Substring(maxCode.Length - 3)) + 1;
        return maxCode.Substring(0, maxCode.Length - 3) + subNumber.ToString("D3");
    }
    else
    {
        // 第一层递增
        int majorNumber = int.Parse(maxCode.Substring(1)) + 1;
        return "B" + majorNumber.ToString("D2");
    }
}
记录校验与添加
private async Task<SpAdjustmentDict> EnsureRecordExistsAsync(
    string name,
    int level,
    SysUser user,
    Guid? parentId = null)
{
    if (string.IsNullOrEmpty(name)) return null;

    var existingRecord = parentId.HasValue
        ? await _adjustmentDictService.SelectByNameAndLevelAndPid(name, level, parentId.Value)
        : await _adjustmentDictService.SelectByNameAndLevel(name, level);

    if (existingRecord != null) return existingRecord;

    string code = await GenerateCodeAsync(level, parentId);

    var newRecord = new SpAdjustmentDict
    {
        Name = name,
        Code = code,
        Level = level,
        Pid = parentId,
        LogicDelFlg = false,
        InsertBy = user.UserName,
        UpdateBy = user.UserName,
        InsertTime = DateTime.Now,
        UpdateTime = DateTime.Now,
        InsertById = user.Id,
        UpdateById = user.Id
    };

    return await _adjustmentDictService.Add(newRecord);
}

优化与扩展
  1. 并发问题

    • 为防止并发导致重复编码,可在数据库中为 Code 列添加唯一约束。
    • 使用事务或锁机制确保线程安全。
  2. 高性能需求

    • 考虑缓存每个层级的最大编码,减少数据库查询频率。
  3. 适配更多规则

    • 可以通过配置文件或参数传递动态调整编码规则(如修改前缀或位数)。
  4. 日志记录

    • 在编码生成过程中记录详细日志,便于排查问题。

总结

通过设计规则清晰、递增逻辑严谨的编码生成方法,可以轻松实现分层结构中的唯一编码需求。这种通用方法适用于多种场景,如组织架构、商品分类等。在实际应用中,根据业务特点调整规则与性能优化策略,可以使编码系统更加高效可靠。

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

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

相关文章

探索 Python 任务自动化的新境界:Invoke 库揭秘

文章目录 探索 Python 任务自动化的新境界&#xff1a;Invoke 库揭秘背景&#xff1a;为何选择 Invoke&#xff1f;什么是 Invoke&#xff1f;如何安装 Invoke&#xff1f;5个简单的库函数使用方法1. 定义任务2. 带参数的任务3. 运行 Shell 命令4. 任务参数化5. 列出任务 场景应…

利用Prompt工程为LLM提升推理能力

利用Prompt工程为LLM提升推理能力 基于策略的推理详解ReAct: 推理与行动思维链&#xff1a;逐步解决问题反思&#xff1a;深入分析和自我审查与代理架构的集成实际应用代码附录 众所周知&#xff0c;一个精心设计的Prompt能够显著增强大型语言模型&#xff08;LLMs&#xff09;…

C#开发合集

用C#轻松搞定m3u8视频下载与合并 嘿&#xff0c;程序员们&#xff01;今天咱们来聊聊如何用C#写个小程序&#xff0c;轻松下载和合并m3u8视频文件。没错&#xff0c;就是那种分段的流媒体视频。准备好了吗&#xff1f;让我们开始吧&#xff01; 准备工作 在动手之前&#xf…

java框架Netty网络编程——问鼎篇

Netty进阶 粘包现象 案例 服务端代码 public static void main(String[] args) {NioEventLoopGroup bossGroupnew NioEventLoopGroup(1);NioEventLoopGroup workerGroupnew NioEventLoopGroup(2);try {ServerBootstrap serverBootstrap new ServerBootstrap();serverBootstr…

堤防安全监测系统方案

一、背景情况 堤防是开发利用水资源和防治水灾害的重要工程措施之一&#xff0c;对防洪、供水、生态、发电、航运等至关重要。我国现有堤防9.8万多座&#xff0c;其中大中型堤防4700多座、小型堤防9.4万座&#xff0c;80%以上修建于上世纪50至70年代。由于堤防管护力量薄弱&am…

模型减肥秘籍:模型压缩技术 知识蒸馏

教程链接&#xff1a;模型减肥秘籍&#xff1a;模型压缩技术-课程详情 | Datawhale 知识蒸馏&#xff1a;让AI模型更轻更快 在人工智能快速发展的今天&#xff0c;我们经常需要在资源受限的设备&#xff08;如手机、IoT设备&#xff09;上运行AI模型。但这些设备的计算能力和…

golang实现TCP服务器与客户端的断线自动重连功能

1.服务端 2.客户端 生成服务端口程序: 生成客户端程序: 测试断线重连: 初始连接成功

React表单联动

Ant Design 1、dependencies Form.Item 可以通过 dependencies 属性&#xff0c;设置关联字段。当关联字段的值发生变化时&#xff0c;会触发校验与更新。 一种常见的场景&#xff1a;注册用户表单的“密码”与“确认密码”字段。“确认密码”校验依赖于“密码”字段&#x…

springboot实战(16)(Validation参数校验冲突问题、分组校验、默认分组)

目录 一、注解NotNull与NotEmpty区别。 二、Validation提供的分组校验。&#xff08;参数校验冲突问题&#xff09; &#xff08;1&#xff09;基本介绍。 &#xff08;2&#xff09;实际案例。 &#xff08;3&#xff09;大模型提问提供的方法。 1、定义分组接口。 2、在字段上…

学Linux的第九天--磁盘管理

目录 一、磁盘简介 &#xff08;一&#xff09;、认知磁盘 &#xff08;1&#xff09;结构 &#xff08;2&#xff09;物理设备的命名规则 &#xff08;二&#xff09;、磁盘分区方式 MBR分区 MBR分区类型 扩展 GPT格式 lsblk命令 使用fdisk管理分区 使用gdisk管理分…

【ubuntu+win】Win10+Ubuntu22.04双系统给ubuntu系统中的某个分区进行扩容(从400G->800G)数据无损坏

给ubuntu已分区的部分进行扩容 1. 准备扩容的空间2.进入ubuntu系统进行卸载分区3.安装图形界面的安装包4.进行对分区扩容5. 重新挂载 我的情况是这式的&#xff08;可以不看&#xff0c;直接看后面的&#xff09;&#xff1a; 刚开始买下电脑的时候&#xff0c;只装了一个 1T 的…

流式上传与分片上传的原理与实现

&#x1f680; 博主介绍&#xff1a;大家好&#xff0c;我是无休居士&#xff01;一枚任职于一线Top3互联网大厂的Java开发工程师&#xff01; &#x1f680; &#x1f31f; 在这里&#xff0c;你将找到通往Java技术大门的钥匙。作为一个爱敲代码技术人&#xff0c;我不仅热衷…

Ettus USRP X410

总线连接器: 以太网 RF频率范围: 1 MHz 至 7.2 GHz GPSDO: 是 输出通道数量: 4 RF收发仪瞬时带宽: 400 MHz 输入通道数量: 4 FPGA: Zynq US RFSoC (ZU28DR) 1 MHz to 7.2 GHz&#xff0c;400 MHz带宽&#xff0c;GPS驯服OCXO&#xff0c;USRP软件无线电设备 Ettus USRP X410集…

oracle 19c RAC到单机ogg部署安装

源端&#xff08;RAC&#xff09;目标端&#xff08;FS&#xff09;IP192.168.40.30/31192.168.40.50数据库版本Oracle 19.3.0Oracle 19.3.0主机名hfdb30/hfdb31hfogg操作系统REHL7.6REHL7.6数据库实例hfdb1/hfdb2hfogg同步用户hfdb1hfdb1同步表testtestOGG版本19.1.0.0.419.1.…

现代密码学

概论 计算机安全的最核心三个关键目标&#xff08;指标&#xff09;/为&#xff1a;保密性 Confidentiality、完整性 Integrity、可用性 Availability &#xff0c;三者称为 CIA三元组 数据保密性&#xff1a;确保隐私或是秘密信息不向非授权者泄漏&#xff0c;也不被非授权者使…

QT QGridLayout控件 全面详解

本系列文章全面的介绍了QT中的57种控件的使用方法以及示例&#xff0c;包括 Button(PushButton、toolButton、radioButton、checkBox、commandLinkButton、buttonBox)、Layouts(verticalLayout、horizontalLayout、gridLayout、formLayout)、Spacers(verticalSpacer、horizonta…

Adobe Illustrator 2024 安装教程与下载分享

介绍一下 下载直接看文章末尾 Adobe Illustrator 是一款由Adobe Systems开发的矢量图形编辑软件。它广泛应用于创建和编辑矢量图形、插图、徽标、图标、排版和广告等领域。以下是Adobe Illustrator的一些主要特点和功能&#xff1a; 矢量绘图&#xff1a;Illustrator使用矢量…

IDEA2023设置控制台日志输出到本地文件

1、Run->Edit Configurations 2、选择要输出日志的日志&#xff0c;右侧&#xff0c;IDEA2023的Logs在 Modify option 里 选中就会展示Logs栏。注意一定要先把这个日志文件创建出来&#xff0c;不然不会自动创建日志文件的 IDEA以前版本的Logs会直接展示出来 3、但是…

[UE5学习] 一、使用源代码安装UE5.4

一、简介 本文介绍了如何使用源代码安装编译UE5.4&#xff0c;并且新建简单的项目&#xff0c;打包成安卓平台下的apk安装包。 二、使用源代码安装UE5.4 注意事项&#xff1a; 请保证可以全程流畅地科学上网。请保证C盘具有充足的空间。请保证接下来安装下载的visual studi…

细说敏捷:敏捷四会之standup meeting

上一篇文章中&#xff0c;我们讨论了 敏捷四会 中 冲刺计划会 的实施要点&#xff0c;本篇我们继续分享敏捷四会中实施最频繁&#xff0c;团队最容易实施但往往也最容易走形的第二个会议&#xff1a;每日站会 关于每日站会的误区 站会是一个比较有标志性的仪式活动&#xff0…