Delphi

本类阅读TOP10

·分布式网络考试系统原型分析及实现
·游戏外挂设计技术探讨①
·使用HOOK随心监视Windows
·Delphi 水晶报表打包解决
·试题库开发中非文本数据的处理
·如何将几个DBGRID里的内容导入同一个EXCEL表中....的问题
·如何使用Delphi设计强大的服务器程序
·工人线程中关闭窗体的实现
·用DLL方式封装MDI子窗体。
·支持XP下托盘栏气球提示的托盘单元

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
SQLServer中一个多用户自动生成编号的过程

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

if not exists (select * from dbo.sysobjects where id = object_id(N'[IndexTable]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
create table IndexTable(Ex char(20), num integer)

go

create procedure SetIndex @Ex char(20),@result char(30) output,@Fmt integer
as
  declare @num char(10)
  SET NOCOUNT on
  if not exists(select num from indextable where Ex=@ex )
   insert into indextable values(@ex,1)
  else
   update indextable set num=num+1
  select @num=cast(num as char(10)) from indextable where ex=@ex
  select @num=space(@fmt-len(@num))+@num
  select @num=replace(@num,' ','0')
  select @result=rtrim(@ex)+rtrim(@num)
  SET NOCOUNT off
go

--------

在delphi中调用

procedure TForm1.Button1Click(Sender: TObject);
begin
  StoredProc1.ParamByName('@Ex').AsString:='User';
  StoredProc1.ParamByName('@fmt').AsInteger:=3;
  StoredProc1.ExecProc;
  showmessage(StoredProc1.ParamByName('@result').value)
end;

-----------
参数@ex表示前缀,@fmt表示数字长度,@result表示返回数据
返回User001




相关文章

相关软件