--1、借助newid()

Go

--创建视图(因为在函数中无法直接使用newid())

create view vnewid

as

select newid() N'MacoId';

go

--创建函数

create function getrandstr(@n int)

returns varchar(max)

as

begin

declare @i int

set @i=ceiling(@n/32.00)

declare @j int

set @j=0

declare @k varchar(max)

set @k=''

while @j<@i

begin

select @k=@k+replace(cast(MacoId as varchar(36)),'-','') from vnewid

set @j=@j+1

end

set @k=substring(@k,1,@n)

return @k

end

--测试示例

select dbo.getrandstr(75)

--运行结果

/*

D185504AD09C4D5796F7016983E67414CEE25162EA9F43D195D43328A4CF01AC7C586521D8E

*/

--我们可以发现结果中的字母都是大写的,或是都是小写的。

--换种方法来写下:

go

--创建函数

create function [dbo].[m_rand](@mycount int)

returns nvarchar(2000)

as

begin

declare @maco_wang table (id varchar(1))

declare @maco_number int,@number int;

declare @my_one nvarchar(max),@my_two nvarchar(max)

set @my_one='';set @maco_number=0; set @number =48;

while (@number>=48 and @number<=57) or (@number>=65 and @number<=90) or (@number>=97 and @number<=122)

begin

insert into @maco_wang select char(@number)

set @number=@number+1;

if(@number=58)

begin

set @number=65

end

if(@number=91)

begin

set @number=97

end

end

while @maco_number<@mycount

begin

select @my_two=id from @maco_wang

order by (select MacoId from dbo.m_macoview);

set @my_one=@my_two+@my_one;

set @maco_number=@maco_number+1;

end

return @my_one

end

--测试用例

select [dbo].[m_rand](75)

--运行结果

/*

5nN0w4o4VOkjacB5so2uvCuw2ZRrnBhxEi4IcsEOHzBbStKmR1p8ASH4N4XaxhDoDEtkX8bZ0CR

*/

最新文章

  1. 轻松实现localStorage本地存储
  2. ajax与后台交互传输数据的工具类
  3. Swift3.0语言教程使用编码创建和初始化字符串
  4. sprint3(第四天)
  5. dataset 使用
  6. cut DEMO
  7. FreebuF黑客专访系列之吴翰清(刺):接下来几年,有两样东西必定会火
  8. 学习笔记 - 数据绑定之knockout
  9. 《JavaScript 闯关记》之单体内置对象
  10. Address already in use: JVM_Bind&lt;null&gt;:8080tomcat启动不了的问题
  11. Docker 01 Introduction
  12. 定制你自己的jQuery
  13. MySQL对NULL值的处理
  14. 用原型代替PRD时,原型应该包含哪些内容
  15. Yum database disk image is malformed
  16. Material Design之CollapsingToolbarLayout使用
  17. C#集合。
  18. 《Java大学教程》—第24章 Java的背景
  19. [LintCode] Max Points on a Line 共线点个数
  20. L245

热门文章

  1. Qt 文件处理
  2. Linux下查看某一进程所占用内存的方法
  3. MySQL 四种事务隔离级的说明
  4. Js 旋转木马 轮播
  5. 【hihoCoder】第20周 线段树
  6. UI课堂笔记
  7. ASP.Net后台 实现先弹出对话框,再跳转到另一个网页的实现方法
  8. valgrind检查C++内存泄漏
  9. Swift - 键盘弹出样式
  10. 微信支付 - V3支付问题