SQL-按自定义格式进行编号的SQL自定义函数.090119

生成格式如:DT.EMP.0000000001的自增emp_id, 加入EmpBaseINfo表中。

--生成格式如DT.EMP.0000000001  【Vegas Add】
ALTERFUNCTION[dbo].[Get_EmpBaseInfo_AccountID](@RowIDasint)
RETURNSnvarchar(50as 
begin
    declare@oidnvarchar(50)
    declare@headStrnvarchar(50)
    set@headStr='DT.EMP.'    
----------------------------RowID的计算--------------------------------------
ifexists(select1from empbaseinfo)
        --如empbaseinfo存在数据,count(*)后直接加RowID
begin
            select@oid=count(1from empbaseinfo  
            set@oid=@oid+@RowID 
        end
    else 
        set@oid=@RowID
       
----------------------------补全十个数------------------------------
declare@strnvarchar(50--临时编号
    set@str=convert(nvarchar,(convert(int,right(@oid,10))))  
    while (10-len(@str)>0)
        begin
             set@str='0'+@str    
        end
    set@oid=@headStr+@str
---------------------------返回值---------------------------------------------------------
RETURN @oid
end     

调用:

select dbo.Get_EmpBaseInfo_AccountID(ROW_NUMBER() OVER(ORDERBY hbdwno)) as id,
        hbdwno,hbdbno,hbdenm,hbdcnm,
        (case hbdgdr when1then'M'when0then'F'end),
        (case hbdidl when1then'IDL'when0then'DL'end),
        hbdwdt,hbdbir,hbdmds,'DT'as domain
from hrmsdt.hrms.dbo.hrshhbd
order by hbdwno
posted @   中国的Amadeus  阅读(2)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示