首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL 生成连续的编号

给大家一分钟,请思考:在你熟悉的数据库里使用 SQL 快速生成 001~999 的编号有哪些方法。 以下是我想到的在 MySQL 中可以实现的方法。...我把这个实现过程分成两部分: 生成 1~999 的序号; 对不足三位数的序号在前面补‘0’。 MySQL 提供了 LPAD() 左填充函数,因此第二部分已经解决。...生成 1~999 的序号的方法有: 找到任意一张记录数大于 1000 的表 t,执行 SELECT ROW_NUMBER() OVER() AS num FROM t LIMIT 999 就能够生成 1...使用递归,关于用递归生成连续序号的文章请看——生成数字序列; 手动生成 0-9 的数字,将这批数字放到临时表中,对临时表重复求笛卡尔积,具体实现后面有讲。...* 10 + c.num AS num FROM t10 a, t10 b, t10 c) t WHERE num > 0 ORDER BY 1 1~999 的编号

4K30

使用redis生成唯一编号

生成ID的方法有很多,每种适用场景、需求以及性能要求不同。下面我们列出以下较为常用的生成ID的方式,并且来讨论以下他们的优缺点。 利用数据库自带的自增功能设置唯一id: 优点:可控并且显而易见。...Redis生成id: 对于大型系统来说,我们可以使用Redis来生成ID,主要是依赖于redis是单线程的,因此可以用来生成全局唯一ID。...下面我们就来看一下如何使用redis生成唯一ID,主要思想是利用redis单线程特性以保证操作的原子性,这样读写同一key时不会出现不同的数据。...代码如下: 首先我们先利用DequeueItemFromList方法循环获取编号GetForeachNumbers, private string GetForeachNumbers(IRedisClient...} } else result = true; } return result; } 最后获取编号

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    订单场景-基于Redisson实现订单生成

    theme: z-blue 订单、指定长度随机码生成是业务系统中重要且不可避免的一个需求,往往在电商系统中,业务量、并发量庞大,如何不重复、快速、安全的生成一个订单号成了需要重点考虑的问题。...这篇文章我将举一个实际的订单生成需求,来和大家一起探究基于Redisson实现订单号的生成。 业务场景 如何避免重复下单?...当生成订单号的逻辑和订单创建、落库逻辑分开,每次点击提交订单时,前端调用单独的生成订单号接口,再拿着生成订单号去请求订单创建、落库的逻辑,每次生成订单号都不一致,这样便保证了每次的请求都不是重复的,...图片来源: 图片来源 不重复订单生成 不重复订单生成实现方式有: UUID 雪花算法 时间戳+随机数+序列号 时间戳+随机数+序列号相比于UUID、雪花算法的优势主要包括以下几点: 可读性:时间戳+...可控性:时间戳+随机数+序列号生成订单号中包含了序列号,可以方便地控制其长度和生成规则,以满足不同业务场景下的需求。

    39710

    SAP IDOC 通过采购订单输出消息生成销售订单

    业务说明: 本功能是用在销售公司接单之后,向生产公司创建采购订单采购物料,系统通过IDOC的设置生成生产公司对销售公司的销售订单。...注意,合作伙伴编号要跟SCC4里面相应的Client的逻辑系统要一致! 如果是在发送端(即新建采购订单的Client里),这里要创建生产公司所在的Client的逻辑系统LS,并设置出站!...如果是在接收端(即生成销售订单的Client里),这里要创建销售公司所在的Client的逻辑系统LS,并设置入站! 因为本例Client只有一个,因此出入站都是在一个逻辑系统里!...切换到接收端,设置合作伙伴参数KU:编号要跟客户编号一致! ? 设置KU的入站参数: ? 四、设置客户与供应商代码的配对参数 事务代码:VOE2 ?...十三、查看生成的销售订单 事务代码:BD87 输入入站的IDOC号码 ? 事务代码:VA03 ? ? EDI1和EDI2价格来自于采购订单里的价格! ?

    3.8K83

    MySQL binlog后面的编号最大是多大?

    导读 每个binlog文件都有编号,从最早的3位数(没错,很老的版本只有3位数~),到现在扩展到6位数,从000001开始计数。 但我打赌,你一定不知道这个序号最大可以跑到多少。...把所有日志文名都写入到 mysql-bin.index 中,并确认 mysql-bin.000001 文件存在(看会不会被覆盖或者其他的)。...看这架势,是想生成 mysql-bin.(1-999) 这样的文件而未果。于是我们再进行下面的测试。...把所有日志文名都写入到 mysql-bin.index 中,并确认 mysql-bin.000001 文件到 mysql-bin.000999 这些文件都不存在(和测试二不同,这次是要确保这些文件不存在...生成新的binlog时,会扫描当前已存在的binlog文件,最终取得最大序号值。因此,如果binlog文件数目特别多的话,是会影响MySQL的启动及日志切换效率的。

    2.6K20

    MySQL binlog后面的编号最大是多大?

    导读 每个binlog文件都有编号,从最早的3位数(没错,很老的版本只有3位数~),到现在扩展到6位数,从000001开始计数。 但我打赌,你一定不知道这个序号最大可以跑到多少。...把所有日志文名都写入到 mysql-bin.index 中,并确认 mysql-bin.000001 文件存在(看会不会被覆盖或者其他的)。...看这架势,是想生成 mysql-bin.(1-999) 这样的文件而未果。于是我们再进行下面的测试。...把所有日志文名都写入到 mysql-bin.index 中,并确认 mysql-bin.000001 文件到 mysql-bin.000999 这些文件都不存在(和测试二不同,这次是要确保这些文件不存在...生成新的binlog时,会扫描当前已存在的binlog文件,最终取得最大序号值。因此,如果binlog文件数目特别多的话,是会影响MySQL的启动及日志切换效率的。

    1.7K20

    新零售mysql设计 订单订单详情表

    作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人) 阿里云专家博主 文章目录 sql 订单表 数据 订单详情表 数据: 订单号与流水号有什么不同?...订单号是跟业务相关的,流水号是跟交易相关的,订单里面一定保存了金额,支付的时候用到流水号,所以两个使用的场景不一样,数据库id没有任何意义,只是一个记录的唯一标识而已 订单表(解析) create table...2)数据库自动编号,速度快,而且是增量增长,按顺序存放,对于检索非常有利; 3)数字型,占用索引空间小,范围查找与排序友好,在程序中传递也方便; 为什么要设置主键,主键作用是什么?...买东西的时候产生订单的过程中。买过程中(产生订单)是不是得出现你是去那家网上商店买的。是不是会员。...“商品id”, 订单详情:需要里面包括的字段:商品id+订单的id

    2.3K110

    PHP生成不重复的订单

    使用场景:商城、微信支付等生成订单号需求 方法一 比较常见的一种简单方法 使用date()函数,获取当前日期的数字,再配合rand()函数,生成几位随机数。便是一个简单的12位订单号了 <?...$rand; } echo getOrderNum(); uniqid()函数基于以微秒计的当前时间,生成一个唯一的 ID。...当时前面的7位是不会经常变动的(应该是秒数,一秒一次) 所以我们使用substr()函数,截取字符串,从第8位到13位,接着这里会有一个问题,得到的是数字+字母的随机数,如果你需要的订单号可以包含字母,...这里为了纯数字的订单号,所以要继续进行处理。 使用str_split($string, 1)函数,将字符串,以一个字符的长度分割成变量。也就是一个字符一个变量。...而且是基于时间微秒来生成的,重复的可能性非常非常低,之所以加上时间日期,是为了看起来更加统一。

    2.8K11
    领券