jjw

写给自己的博客。 记录学习的点滴以备查。
随笔 - 127, 文章 - 0, 评论 - 8, 阅读 - 62632
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

mormot2 笔记(五) 储存过程调用

Posted on   jjw  阅读(120)  评论(0编辑  收藏  举报
复制代码
procedure TForm1.Button1Click(Sender: TObject);
var
  v: variant;
begin
{
[ODBC]
DRIVER=SQL Server   会报错
DRIVER=ODBC Driver 18 for SQL Server   没问题
}
  dbProp := TSqlDBOdbcConnectionProperties.Create('', 'FILEDSN=d:\test.dsn;PWD=Sa12345', '', '');
//  var stmt := dbProp.NewThreadSafeStatementPrepared('{? = call p_test (?,?) }', true, false);  第一个参数是返回值。
  var stmt := dbProp.NewThreadSafeStatementPrepared('exec p_test ?,?', true, false);  //无返回值
  stmt.BindTextU(1, 'jjw', paramIn);
  stmt.Bind(2, 9, paramOut);
  stmt.ExecutePrepared;
  stmt.ParamToVariant(2, v);
  Caption := V;
end;
复制代码
复制代码
ALTER proc [dbo].[p_test]
@name varchar(10),
@insId bigint output
as
begin
    SET NOCOUNT ON  --关键
    insert into test(name) values(@name)
    select @insId = @@IDENTITY
    return 0
end
GO
复制代码

 

相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示