sql 生成随机字符串
生成三位随机字母+12位数字
declare @CardCode varchar(50),@str varchar(50), @c int; select @CardCode=abs(CHECKSUM(NEWID())) set @c=12-LEN(@CardCode); select @str= FLOOR(rand()*POWER(10,@c)) set @CardCode=@CardCode+@str declare @sql nvarchar(400) ,@name varchar(50) ; select @name= char( cONVERT(NVARCHAR,CONVERT(INT,26*rand())+97) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97) ) select @name+CAST( @CardCode as nvarchar(50))
下面这个是生成大写字母的
declare @sql nvarchar(400) ,@name varchar(50) ; select @name= char( cONVERT(NVARCHAR,CONVERT(INT,26*rand())+65) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+65) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+65) ) select @name
生成随机字母+数字的存储过程
ALTER proc [dbo].[randStr] ( @digitalLen int, --数字长度 @letterLen int, --字母长度 @IsCapital bit --大写,1=是 ,0=否 ) --RETURNs varchar(100) as begin declare @CardCode varchar(50),@str varchar(50), @c int,@name varchar(50); if(@IsCapital=0) begin select @CardCode=abs(CHECKSUM(NEWID())) if(@digitalLen>LEN(@CardCode)) begin set @c=@digitalLen-LEN(@CardCode); select @str= FLOOR(rand()*POWER(10,@c)) set @CardCode=@CardCode+@str end else begin set @CardCode=left(@CardCode,@digitalLen) end select @name= char( cONVERT(NVARCHAR,CONVERT(INT,26*rand())+97) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+97) ) set @CardCode= @name+CAST( @CardCode as nvarchar(50)) end else begin select @CardCode=abs(CHECKSUM(NEWID())) if(@digitalLen>LEN(@CardCode)) begin set @c=@digitalLen-LEN(@CardCode); select @str= FLOOR(rand()*POWER(10,@c)) set @CardCode=@CardCode+@str end else begin set @CardCode=left(@CardCode,@digitalLen) end select @name= char( cONVERT(NVARCHAR,CONVERT(INT,26*rand())+65) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+65) )+ CHAR( CONVERT(NVARCHAR,CONVERT(INT,rand()*26)+65) ) set @CardCode= @name+CAST( @CardCode as nvarchar(50)) end select @CardCode; end
分类:
sql
标签:
sql 生成随机字符串
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?