首页
学习
活动
专区
工具
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
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到
    领券