SQL 语句 生成当前时间 年月日小时分钟 再加4个随机数的字符串。

比如:201103070915加4个随机数2315结果为2011030709152315DECLARE@rand。。。。。。SET@rand。。。。。。。。。。。。。结果... 比如:201103070915加4个随机数2315 结果为2011030709152315
DECLARE @rand 。。。。。。
SET @rand 。。。。。。。。。。。。。
结果要为narvchar字符串

我今天都在线
展开
 我来答
laosong2008
2011-03-07 · TA获得超过159个赞
知道小有建树答主
回答量:283
采纳率:0%
帮助的人:244万
展开全部
--测试环境sql2005 2005以下版本可能存在问题
--在自定义函数中不能使用日期函数getdate(),所以这里要建一个视图用来返回当前时间
go
if object_id('viewNow') is not null
begin
drop view viewNow
end
go
Create View viewNow
as
select getdate() as now

--在自定义函数中不能使用函数rand()所以这里要建立一个视图来返回4位随机数字
go
if object_id('viewRandNumber') is not null
begin
drop view viewRandNumber
end
go
Create View viewRandNumber
as
select CEILING(RAND()*10000) as RandNumber

--建立自定义函数
go
if object_id('GenerateCode') is not null
begin
drop function GenerateCode
end
go
create function GenerateCode()
returns varchar(16)
as
begin
declare @now datetime
select @now=now from viewNow
declare @nowVarchar varchar(12)
set @nowVarchar=convert(varchar(8),@now,112)+replace(convert(varchar(8),@now,108),':','')
declare @RandNumber int
select @RandNumber=RandNumber from viewRandNumber
return @nowVarchar+convert(varchar(4),@RandNumber)
end

--测试结果
select dbo.GenerateCode() as code

--code
2011030710478029
百度网友94f02eb
推荐于2016-07-17 · TA获得超过8612个赞
知道大有可为答主
回答量:7955
采纳率:74%
帮助的人:4490万
展开全部
DECLARE @rand NVARCHAR(16)

SET @rand = REPLACE(CONVERT(NVARCHAR(16), GETDATE(), 120), '-', '');
SET @rand = REPLACE(@rand, ' ', '');
SET @rand = REPLACE(@rand, ':', '');
SET @rand = @rand + CAST(FLOOR ((RAND() * 900 + 100)) AS NVARCHAR(3));

PRINT @rand
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
网友gjnfhjvbkk
2011-03-07 · TA获得超过556个赞
知道小有建树答主
回答量:744
采纳率:0%
帮助的人:364万
展开全部
select convert(char(19),getdate(),112)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
翼帆
2011-03-07 · TA获得超过1729个赞
知道小有建树答主
回答量:819
采纳率:60%
帮助的人:518万
展开全部
declare @autoNo as nvarchar(15)
set @autoNo = CONVERT(nvarchar(10), GETDATE(),112) +cast(DATENAME(HOUR,GETDATE()) as nvarchar)+ cast(DATENAME(MINUTE,GETDATE()) as nvarchar) + right('0000' + CAST( cast(rand()*10000 as int) as nvarchar),4)
print @autoNo
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式