oracle存储过程生成流水号,科学网—存储过程生成流水号 - 李芳军的博文

(1)建一个存储生成流水号的表 SriaNum

--/*

CREATE  TABLE [dbo].[SriaNum] (

[Num] [int] NOT NULL

)

--*/

(2)建立生成流水号的存储过程

--DROP PROC dpIDS_GetSerialNumber

--/*

CREATE  PROC dpIDS_GetSerialNumber

@SerialNumber VARCHAR(9) OUTPUT -- 指明为输出参数AS

IF NOT EXISTS(SELECT

*

FROM

SriaNum)

BEGIN

INSERT INTO SriaNum values(1)

END

ELSE

BEGIN

UPDATE SriaNum SET Num=Num+1

END

SELECT

@SerialNumber = REPLICATE('0',9-LEN(Num))+CONVERT(VARCHAR(9),Num)  --生成[000000001, 999999999]范围内的流水号

FROM

SriaNum

--*/

(3)执行存储过程

--/*

DECLARE @TEST VARCHAR(9)

EXECUTE [dbo].dpIDS_GetSerialNumber @TEST OUTPUT   -- 指明为输出变量

SELECT @TEST AS SERIALNUMBER     -- 获得流水号

--*/

------------------------------------

环境:SQL SERVER 2005

******************************************

C#里调用存储过程并获得输出参数值

private  void GetSerialNumber()

{

// Create an connection instance            string Connection = "server = FJLI\SQLEXPRESS; uid = sa; pwd = 123456; database = TestOne";

SqlConnection DataConn = new SqlConnection(Connection);

// Open connection

try

{

if (DataConn.State == ConnectionState.Closed)

{

DataConn.Open();

Console.WriteLine("Database connection successful!");

}

}

catch (SqlException sqex)

{

// Create connection failed                Console.WriteLine(sqex.Message);

return;

}

SqlCommand DBCmd = new SqlCommand("dpIDS_GetSerialNumber", DataConn);                                             DBCmd.CommandType = CommandType.StoredProcedure;

// Output parameter(值得注意的是:这里Add的输出变量必须与存储过程里的输出变量同名,否则会报告“dpIDS_GetSerialNumber 的@SerialNumber参数not supplied”错误!)

SqlParameter param = new SqlParameter("@SerialNumber", SqlDbType.VarChar, 9);

param.Direction = System.Data.ParameterDirection.Output;

DBCmd.Parameters.Add(param);try

{

DBCmd.ExecuteNonQuery();string serialNumber = param.Value.ToString();  //得到输出参数的值

System.Console.WriteLine("SerialNumber: " + serialNumber);

}

catch(SqlException sqex)

{

Console.WriteLine(sqex.Message);

}

try

{

if (DataConn.State == ConnectionState.Open)

{

DataConn.Close();

Console.WriteLine("Database connection successful!");

}

}

catch (SqlException sqex)

{

Console.WriteLine(sqex.Message);

}

}

********************补充**********************

Oracle环境下存储过程生成流水号[000000001,999999999].

(1)  先建一个序列,例如:MSG_SERIALNUMBER_SEQ,设置最小值、最大值、起始值、增量值、是否循环;

(2)  建存储过程,例如:msg_sp_getSerialNumber:

--生成[000000001, 999999999]范围内的流水号

CREATE  OR REPLACE PROCEDURE msg_sp_getSerialNumber(

SerialNumber OUT VARCHAR)

IS     icount number;

BEGIN

SELECT MSG_SERIALNUMBER_SEQ.NEXTVAL INTO icount FROM dual;

SerialNumber := LPAD(TO_CHAR(icount),9,'0');

END msg_sp_getSerialNumber;

(3)  测试。在PL/SQL里右键刚刚建的存储过程,选择“TEST”,再F9。结束既可以看到流水号了!

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

另外,也同样可以用SQL SERVER里面的方法,即建立一个存储流水号的表,存储过程如下:

CREATE  OR REPLACE PROCEDURE msg_sp_getSerialNumber (SerialNumber out VARCHAR2) as

RC_COUNT NUMBER;

BEGIN

SELECT COUNT(*) INTO RC_COUNT FROM MSG_SERIALNUMBER;

IF  RC_COUNT=0   THEN

INSERT INTO MSG_SERIALNUMBER VALUES(1);

else

UPDATE MSG_SERIALNUMBER SET NUM=NUM+1;

END IF;

SELECT LPAD(Num,9,'0') into SerialNumber FROM MSG_SERIALNUMBER;

END;

转载本文请联系原作者获取授权,同时请注明本文来自李芳军科学网博客。

链接地址:http://blog.sciencenet.cn/blog-427149-320445.html

上一篇:按图索骥——新街口豁口外的那些河儿

下一篇:DB Table 到 DataSet 生成 XML

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值