我是靠谱客的博主 大力外套,最近开发中收集的这篇文章主要介绍SQLServer流水号自动生成,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  最近给客户做生成条码的功能时,碰到个问题,需要根据数量自动生成流水号,然后加上客户指定的前缀,组合成条码。

  折腾了一会,最后通过个存储过程实现。  

  --@Prefix 指定前缀,@InitialVal 流水号起始值,@IncrementVal 流水号递增值,@TotalNum 流水号总数,@BitNum 流水号位数
  

  IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id=object_id(N'[dbo].[SP_GenerateSerialNo]') AND OBJECTPROPERTY(id, N'IsProcedure') = 1)
  DROP PROCEDURE [dbo].SP_GenerateSerialNo
  GO

 

  SET QUOTED_IDENTIFIER ON
  GO
  SET ANSI_NULLS ON
  GO

 

  CREATE PROCEDURE SP_GenerateSerialNo @Prefix nvarchar(50), @InitialVal int, @IncrementVal int, @TotalNum int, @BitNum int
  AS
  DECLARE @SQL nvarchar(1000)
  IF EXISTS(SELECT * FROM tempdb..sysobjects WHERE id=object_id('tempdb..##t'))
  DROP TABLE ##t
  SET @SQL=N'SELECT TOP '+CONVERT(nvarchar(10),@TotalNum)+' id=IDENTITY(INT,'+CONVERT(nvarchar(4),@InitialVal)+','+CONVERT(nvarchar(4),@IncrementVal)+') INTO ##t FROM sysobjects,syscolumns'
  --print @SQL
  EXEC sp_executesql @SQL
  SELECT LTRIM(RTRIM(@Prefix))+SUBSTRING(ret, LEN(ret)-@BitNum+1, @BitNum) as SerialNo FROM (
    SELECT '00000000000000000000'+CONVERT(nvarchar(10), id) as ret FROM ##t) a
  --SELECT * FROM ##t
  DROP TABLE ##t
  GO
  SET QUOTED_IDENTIFIER OFF
  GO
  SET ANSI_NULLS ON
  GO

 

  中间碰到个问题,就是组合成的SQL语句,通过EXEC sp_executesql @SQL 执行时,如果语句中是本地临时表(#)就会报错,如下图,改成全局临时表(##)可解决。

  

  测试:exec SP_GenerateSerialNo 'test', 10,3,1000,6

  结果:

    ~  

转载于:https://www.cnblogs.com/mozzie/p/4939607.html

最后

以上就是大力外套为你收集整理的SQLServer流水号自动生成的全部内容,希望文章能够帮你解决SQLServer流水号自动生成所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(42)

评论列表共有 0 条评论

立即
投稿
返回
顶部