vc++中,用ado执行sql server存储过程,并且取得返回值的例子

简介: vc++中,用ado执行sql server存储过程,并且取得返回值的例子
variant_t RecordsAffected; string szSql = (string)"P_KS_ADDUSER '" + 
m_szName+ "','" + m_szPasswd +"';"; try {  _CommandPtr 
ptrCmd;  ptrCmd.CreateInstance(__uuidof(Command));  ptrCmd->ActiveConnection = pContext-
>GetConnection();   VARIANT vtRoyalty;   vtRoyalty = COleVariant((long)0);  ptrCmd->Parameters-
>Append(   ptrCmd->CreateParameter("Return", adInteger, 
adParamReturnValue,sizeof(int),vtRoyalty));   vtRoyalty = COleVariant(m_szName.c_str());  ptrCmd-
>Parameters->Append(   ptrCmd->CreateParameter("Name", adChar, 
adParamInput,m_szName.size(),vtRoyalty));   vtRoyalty = 
COleVariant(m_szPasswd.c_str());  ptrCmd->Parameters->Append(   ptrCmd
->CreateParameter("Pass", adChar, adParamInput,m_szPasswd.size(),vtRoyalty));   ptrCmd-
>CommandText = "P_KS_ADDUSER";  ptrCmd->CommandType = adCmdStoredProc;  ptrCmd-
>Execute(NULL,NULL,adCmdStoredProc);   cout<<"添加用户成功,id="<<(unsigned int)ptrCmd
->Parameters->GetItem("Return")->GetValue()<<endl;  //cout<<"add id:"<<(unsigned int)ptrCmd-
>GetParameters()->GetItem(0)<<endl;  //pContext->GetNetworkSender()
->SendPack(); } catch(_com_error e) {  cout<<"增加用户的时候发生异常:"<<(LPCSTR)e.Description()
<<endl;  return; }


要是有多个值要返回,那么可以使用输出参数(output parameter)的方法;要是需要返回一个数组,可以使用返回数据集的方法。

相关文章
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
468 1
|
存储 SQL 数据库连接
C#程序调用Sql Server存储过程异常处理:调用存储过程后不返回、不抛异常的解决方案
本文分析了C#程序操作Sql Server数据库时偶发的不返回、不抛异常问题,并提出了解决思路。首先解析了一个执行存储过程的函数`ExecuteProcedure`,其功能是调用存储过程并返回影响行数。针对代码执行被阻塞但无异常的情况,文章总结了可能原因,如死锁、无限循环或网络问题等。随后提供了多种解决方案:1) 增加日志定位问题;2) 使用异步操作提升响应性;3) 设置超时机制避免阻塞;4) 利用线程池分离主线程;5) 通过信号量同步线程;6) 监控数据库连接状态确保可用性。这些方法可有效应对数据库操作中的潜在问题,保障程序稳定性。
917 11
|
存储 SQL 数据库
数据库sql语句-----游标和存储过程
数据库sql语句-----游标和存储过程
291 1
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
891 6
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第17天】SQL Server 存储过程是预编译的 SQL 语句集,存于数据库中,可重复调用。它能提高性能、增强安全性和可维护性,但也有可移植性差、开发调试复杂及可能影响数据库性能等缺点。使用时需权衡利弊。
372 3
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
723 1
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
905 1
|
存储 SQL 数据库
SQL Server 临时存储过程及示例
SQL Server 临时存储过程及示例
279 3
|
存储 SQL 安全
【数据库高手的秘密武器:深度解析SQL视图与存储过程的魅力——封装复杂逻辑,实现代码高复用性的终极指南】
【8月更文挑战第31天】本文通过具体代码示例介绍 SQL 视图与存储过程的创建及应用优势。视图作为虚拟表,可简化复杂查询并提升代码可维护性;存储过程则预编译 SQL 语句,支持复杂逻辑与事务处理,增强代码复用性和安全性。通过创建视图 `high_earners` 和存储过程 `get_employee_details` 及 `update_salary` 的实例,展示了二者在实际项目中的强大功能。
306 1
|
存储 SQL 安全