动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库学院 > 数据库技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ 数据库技巧 ]的信息



本月文章推荐
.通过数据仓库来实现少花钱多办事.
.解决SqlTransaction用尽的问题(.
.SQL Server安装文件挂起错误解决.
.教你轻松掌握数据仓库的规划和构.
.如何得到两个相邻snap_id中的一个.
.SQL Server 2005数据加密技术应用.
.使用 SQL Server 2005 数据库镜像.
.使用SQL语句获取SQL Server数据库.
.修改SQL Server2005数据库中的逻.
.sql server 2000 游标用法小例.
.教你使用SQL Server数据库进行网.
.全文本检索的应用(2).
.Microsoft SQL Server数据备份处.
.解决windows 2003+Sql2000中OLED.
.如何清除SQL日志.
.循环插入一定时间范围内的随机日.
.全面解析数据挖掘的分类及各种分.
.32位到64位的sql server移植.
.SQL SERVER的数据类型 && SQLSer.
.实例讲解SQL查询连续号码段的巧妙.

Sql Server中利用自定义函数完成单据流水号的设计

发表日期:2007-6-16 |


流水号是现在各类系统中单据的必备字段,因为流水号很容易标识一个新的单据.
之前我也做了这么一个系统,流水号的格式为:单据前缀+业务日期+几位顺序编号.
知道了流水号的固定格式,设计流水号就非常方便了.
在SqlServer中,我们可以通过客户端程序来生成新的流水号,也可以利用存储过程来生成.
在实际的项目中,我觉得利用自定义函数来生成非常方便,方便存储过程调用,也方便客户端的调用.
说了一大堆废话,来看代码吧.
1.主调用函数,由于在设计过程中有很多类似单据表,而且每个单据表包含了一个相同的流水号字段,所以为了方便代码调用,提供了对应表的输入参数.
/**//*
获取一条新的单据流水号
-流水号格式为 @PrefixString+'-'+当前日期+4位顺序编号:CGRK-20070509-0001
*/

CREATE FUNCTION dbo.fn_GetNewFlowNumber
(
@SheetTableName varchar(50)
)
RETURNS varchar(50)  AS 
BEGIN

    --流水号前缀
    declare @PrefixString varchar(50)
    --流水号后缀数字的位数
    declare @PostfixLength int   
    --定义好当日单据所有的流水号数据表
    declare @Table table(SheetNo varchar(50))
    --1.取得单据的最后一条SheetNo
    IF @SheetTableName=null OR @SheetTableName=''
        return ''
    /**//*库存部分*/
    --其他入库
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_StoreInSheet')
        BEGIN
            SET @PrefixString='QTRK'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_StoreInSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --其他出库
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_StoreOutSheet')
        BEGIN
            SET @PrefixString='QTCK'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_StoreOutSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
           
        END
    --转仓
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_StoreTransferSheet')
        BEGIN
            SET @PrefixString='CKZC'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_StoreTransferSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --盘点
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_StoreCheckSheet')
        BEGIN
            SET @PrefixString='CKPD'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_StoreCheckSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    /**//*采购单据操作部分*/
    --请购单
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_PurchaseRequestSheet')
        BEGIN
            SET @PrefixString='QGD'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_PurchaseRequestSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --采购订单
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_PurchaseOrderSheet')
        BEGIN
            SET @PrefixString='CGDD'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_PurchaseOrderSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL

        END
    --采购询价单
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_PurchaseQuotationSheet')
        BEGIN
            SET @PrefixString='CGXJ'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_PurchaseQuotationSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --采购入库单
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_PurchaseInSheet')
        BEGIN
            SET @PrefixString='CGRK'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_PurchaseInSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --采购退货
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_PurchaseReturnSheet')
        BEGIN
            SET @PrefixString='CGTH'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_PurchaseReturnSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --付款单
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_PurchasePaymentSheet')
        BEGIN
            SET @PrefixString='CGFK'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_PurchasePaymentSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
       
    /**//*销售单据操作部分*/
    --销售询价
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_SaleQuotationSheet')
        BEGIN
            SET @PrefixString='XSXJ'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_SaleQuotationSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --销售订单
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_SaleOrderSheet')
        BEGIN
            SET @PrefixString='XSDD'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_SaleOrderSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --销售出库
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_SaleOutSheet')
        BEGIN
            SET @PrefixString='XSCK'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_SaleOutSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --销售退货
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_SaleReturnSheet')
        BEGIN
            SET @PrefixString='XSTH'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_SaleReturnSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END
    --销售付款
    ELSE IF  LOWER(@SheetTableName)=LOWER('AT_SalePaymentSheet')
        BEGIN
            SET @PrefixString='XSFK'
            SET @PostfixLength=4
            INSERT INTO @Table(SheetNo) SELECT SheetNo FROM AT_SalePaymentSheet WHERE DateDiff(d,CreateTime,dbo.fn_getNowDate())=0 OR CreateTime=NULL
        END

    /**//*不属于任何单据,返回空的单号*/
    ELSE
        RETURN ''
   
    /**//*
    存在一个当日同前缀的流水号的条件:
    1.流水号总长度相同
    2.相同的流水号前缀
    3.相同的中间日期部分           
    */
    --当日日期部分字符串
    declare @DateString varchar(8)
    SET @DateString=dbo.fn_FormatDate(dbo.fn_GetNowDate())
    --记录中最后一条流水号
    declare @LastSheetNo varchar(50)
    /**//*--定义好相关参数,比较是否有相同的流水号前缀*/
    --存在,获取最后一条流水+1           
    SELECT TOP 1 @LastSheetNo=SheetNO FROM @Table WHERE
         LEN(SheetNO)=len(@PrefixString)+10+@PostfixLength
         AND  LEFT(SheetNO,len(@PrefixString+'-'))=@PrefixString+'-'
        AND LEFT(SheetNO,len(@PrefixString+'-'+@DateString+'-'))=@PrefixString+'-'+@DateString+'-'
        ORDER BY  SheetNo DESC
    --return 'ssss'
    IF @LastSheetNo=NULL
        return @PrefixString+'-'+@DateString+'-'+dbo.fn_FillNumberWithZero(1,@PostfixLength)
    ELSE
        return @PrefixString+'-'+@DateString+'-'+dbo.fn_FillNumberWithZero(convert(int,right(@LastSheetNo,@PostfixLength))+1,@PostfixLength)
   
    return ''

END

2.相关函数


/**//*
生成流水号后面几位数字字符的相关函数
不足位数在左边用0填充
*/
CREATE FUNCTION dbo.fn_FillNumberWithZero
(
--填充的数字
@num int,
--总位数
@len int
)
RETURNS varchar(50) AS 
BEGIN
    --如果传入的流水号大于总的长度,那么直接返回流水号字符串格式
    if(len(Convert(varchar(50),@num))>@len)
        return Convert(varchar(50),@num)
    ELSE
        BEGIN
            --需要填充0的位数
            declare @NeedFillLen int
            set @NeedFillLen=@Len-len(Convert(varchar(50),@num))
            --获取需要填充的0的字符串
            declare @i int
            set @i=0
            declare @temp varchar(50)
            set @temp=N''
            while @i<@NeedFillLen
                BEGIN
                    SET @temp=@temp+'0'
                    SET @i=@i+1
                END
            --返回组后的字符串
            return @temp+Convert(varchar(50),@num)
        END
    return ''
END


/**//*
流水号函数相关函数
返回某个日期的格式化形式如20070509

*/
CREATE FUNCTION dbo.fn_FormatDate(@Date datetime)
RETURNS char(8) AS 
BEGIN
    declare @year char(4)
    declare @month char(2)
    declare @day char(2)
   
    set @year=convert(char(4),year(@Date))
    set @month=convert(char(4),month(@Date))
    set @day=convert(char(4),day(@Date))
   
    if len(@month)=1
        set @month=N'0'+@month
    if len(@day)=1
        set @day=N'0'+@day
    return @year+@month+@day
END

/**//*
获取当天日期
*/

CREATE FUNCTION dbo.fn_GetNowDate()
RETURNS DateTime AS 
BEGIN
    declare @nowDate datetime
    select @nowDate=NowDate FROM v_DateNow
    return @nowDate
END


注意这里由于sqlserver的自定义函数无法直接获取日期(无法调用getdate()函数),所以我们通过视图的方式来获取服务器的时间.视图如下:
/**//*
获取当前系统日期
这个视图主要供自定义函数调用,
切勿删除!!!!!!!
*/

CREATE VIEW dbo.v_DateNow
AS
SELECT GETDATE() AS NowDate

全部函数完毕.如何调用呢?
很简单:
比如需要入库单的新流水号:
select dbo.fn_GetNewFlowNumber('AT_StoreCheckSheet')
是不是非常方便?


上一篇:如何应用SQL Server DBCC避免堵塞 人气:2198
下一篇:如何修改数据库表或存储过程的所有者 人气:4855
浏览全部Sql Server的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-6 飞天论坛FTBBS ASP v6.3 Build 0
2008-7-6 飞天论坛FTBBS ASP v6.3 Build 0
2008-7-6 飞天论坛FTBBS ASP v6.8 Build 0
2008-7-6 讯息内容管理系统 v2.1
2008-7-6 三五电影程序 v2.0
2008-7-6 神鹰腾讯小说小偷 v3.0
2008-7-6 EasyIDE Framework v1.0 Build 2
2008-7-6 品告CMS系统(电影版) v0.9
2008-7-6 QQ自动登录器 C# 源码 v1.0
2008-7-5 AgileMessenger即时通讯工具 v1.
2008-7-5 GoodCalculator2.0版固件计算器
2008-7-5 RepoName源地址搜索工具 v1.21b
2008-7-5 AgileMessenger即时通讯工具 v1.
2008-7-5 TouchCopy多媒体管理软件 v3.13完
2008-7-5 VideosTone视频铃声 v1.1汉化破解
2008-7-5 TouchPad触摸板 v4.44破解版
2008-7-5 VideosTone破解补丁 v1.0
2008-7-5 Feeds GoogleReader客户端 v0.4.3


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報