SQL SERVER中 利用方法生成流水号
2010-05-28 12:26
295 查看
/*
功能:利用函数创建流水号如:
fx201005260001,
fx201005260002,
fx201005270001
作者:陈永建
创建时间:2010-05-26
*/
use master
go
if(db_id('NumberDB')is not null)
drop database NumberDB
go
create database NumberDB
GO
USE NumberDB
go
if(object_id('number')is not null)
drop table number
go
create table number
(
id varchar(50) not null,
CreateDate datetime not null
)
go
select * from number
--创建函数生成流水号
if(object_id('fun_CreateNum')is not null)
drop function fun_CreateNum
go
--@profix 前缀
--@dateFormat 日期格式如20050512 :获取当天的日期
--@length 长度:根据你的实际需求来填写你的长度(交易量少则长度短些)
create function fun_CreateNum(@profix varchar(10),@dateFormat varchar(20),@length int)
returns varchar(100)
as
begin
declare @MyNo varchar(100)
select @MyNo= max(id) from number where datediff (dd,CreateDate,getdate())=0 --得到当天最大流水号
--isnull(目标参数,设置的值):如果目标参数为空则变为设定值
set @MyNo=convert(int,isnull(right(@MyNo,@length),0))+1 --如果今天有记录,则在最大的流水号上加1
--replicate(设定值,重复次数): 将设定值重复
set @MyNo=right(replicate(0,@length)+@MyNo,@length)--将@MyNo前加0后截取相应的位数
set @MyNo=@profix+@dateFormat+@MyNo--拼接成流水号
return @MyNo
end
go
--调用函数
--convert(varchar(20),getdate(),112):112将日期格式设置为如:20050512格式
select dbo.fun_CreateNum('fx',convert(varchar(20),getdate(),112),5)
--将流水号插入数据表中
insert into number values(dbo.fun_CreateNum('fx',convert(varchar(20),getdate(),112),5),getdate())
go
select * from number
功能:利用函数创建流水号如:
fx201005260001,
fx201005260002,
fx201005270001
作者:陈永建
创建时间:2010-05-26
*/
use master
go
if(db_id('NumberDB')is not null)
drop database NumberDB
go
create database NumberDB
GO
USE NumberDB
go
if(object_id('number')is not null)
drop table number
go
create table number
(
id varchar(50) not null,
CreateDate datetime not null
)
go
select * from number
--创建函数生成流水号
if(object_id('fun_CreateNum')is not null)
drop function fun_CreateNum
go
--@profix 前缀
--@dateFormat 日期格式如20050512 :获取当天的日期
--@length 长度:根据你的实际需求来填写你的长度(交易量少则长度短些)
create function fun_CreateNum(@profix varchar(10),@dateFormat varchar(20),@length int)
returns varchar(100)
as
begin
declare @MyNo varchar(100)
select @MyNo= max(id) from number where datediff (dd,CreateDate,getdate())=0 --得到当天最大流水号
--isnull(目标参数,设置的值):如果目标参数为空则变为设定值
set @MyNo=convert(int,isnull(right(@MyNo,@length),0))+1 --如果今天有记录,则在最大的流水号上加1
--replicate(设定值,重复次数): 将设定值重复
set @MyNo=right(replicate(0,@length)+@MyNo,@length)--将@MyNo前加0后截取相应的位数
set @MyNo=@profix+@dateFormat+@MyNo--拼接成流水号
return @MyNo
end
go
--调用函数
--convert(varchar(20),getdate(),112):112将日期格式设置为如:20050512格式
select dbo.fun_CreateNum('fx',convert(varchar(20),getdate(),112),5)
--将流水号插入数据表中
insert into number values(dbo.fun_CreateNum('fx',convert(varchar(20),getdate(),112),5),getdate())
go
select * from number
相关文章推荐
- SQL Server无法生成FRunCM线程的解决方法
- Lotus生成流水号方法
- asp.net利用后台实现直接生成html分页的方法
- 关于利用JDK1.5中自带的Java.util生成GUID的方法
- 利用Redis生成业务流水号思路
- 如何利用PowerDesign9.5生成带有列注释的SQL SERVER 2000数据库
- 利用Linux系统生成随机密码的10种方法
- 利用mysql触发器生成流水号
- 【就你不知道-利用velocity生成as get/set方法】
- 生成连续流水号的方法介绍
- 高并发环境下生成订单唯一流水号方法:SnowFlake
- Asp.net_关于如何利用编译器把[.cs]文件生成动态链接库[.dll]文件方法的总结
- SQL SERVER 根据日期自动生成流水号
- Qemu中生成针对具体体系结构的纯净代码的方法---利用GCC的-E选项
- ASM(六) 利用TreeApi 动态生成以及转换方法字节码
- 能利用myeclipse自动生成WSDL对Java类中方法的返回值是有要求的
- (原创)利用扩展方法,给 IEnumerable<T> 增加一个生成 Html 的 select 标签的方法,不用 C# 中的反射技术
- 利用Java生成静态HMTL页面的方法
- 利用hibernate自动生成数据表的方法
- 利用Redis和Jwt实现Token生成,存储,验证方法