• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
西门吹雪
非我伤春春伤我,风一阵,雨一阵,好景不在哀残痕。 非我厌世世厌我,闲言来,碎语去,红颜憔悴心头冷。
博客园    首页    新随笔    联系   管理    订阅  订阅

自动编号

我想实现的就像是自动编号identity那样.但identity是以全数字的.
我要实现的是OR070717001
OR是固定不变的,070717是根据取当天日期除去了开头的20,001是根据当天的订单数据来判断的.001表示,每天第一个订单从001开始
create table tba(OrderID varchar(50),b int)
----------------------------------
CREATE function new_idw(@a datetime) returns varchar(50)
begin
   declare @id varchar(50),@i int
   select top 1 @id=OrderID from tba where left(OrderID,8)='SR'+convert(varchar(6),@a,12) order by OrderID desc
   if @@rowcount=0
      return 'SR'+convert(varchar(6),@a,12)+'001'
   set @i= rtrim(right(@id,3))  +1
   set @id=rtrim(@i)
   return 'SR'+convert(varchar(6),@a,12)+right(  '000'+@id ,3 )
end
------------------------------------------
insert tba select dbo.new_idw(getdate()),1
insert tba select dbo.new_idw(getdate()),2
insert tba select dbo.new_idw(getdate()+1),3
insert tba select dbo.new_idw(getdate()+1),3
select * from tba
posted @ 2007-07-19 19:08  西门吹雪  阅读(200)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3