- 浏览: 2037316 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (651)
- ACE (35)
- BAT (9)
- C/C++ (116)
- fast-cgi (14)
- COM (27)
- python (59)
- CGI (4)
- C# (2)
- VC (84)
- DataBase (29)
- Linux (96)
- P2P (6)
- PHP (15)
- Web (6)
- Memcached (7)
- IME输入法 (11)
- 设计模式 (2)
- 搜索引擎 (1)
- 个人情感 (4)
- 笔试/面试 (3)
- 一亩三分地 (33)
- 历史 (2)
- 地理 (1)
- 人物 (3)
- 经济 (0)
- 不仅仅是笑哦 (43)
- 小故事大道理 (2)
- http://www.bjdsmyysjk120.com/ (0)
- http://www.bjdsmyy120.com/ (0)
- 它山之石可以攻玉 (15)
- 大学生你关注些什么 (28)
- 数据恢复 (1)
最新评论
-
luokaichuang:
这个规范里还是没有让我明白当浏览器上传文件时,STDIN的消息 ...
FastCGI规范 -
effort_fan:
好文章!学习了,谢谢分享!
com技术简介 -
vcell:
有错误os.walk(strPath)返回的已经是全部的文件和 ...
通过python获取目录的大小 -
feifeigd:
feifeigd 写道注意:文章中的CPP示例第二行 #inc ...
ATL入门:利用ATL编写简单的COM组件 -
feifeigd:
注意:文章中的CPP示例第二行 #include " ...
ATL入门:利用ATL编写简单的COM组件
//--------------------------------------------------------------------------------- //修改或者插入用户的积分信息 //modify by yanxiang 20061113 //增加差值判断 //修改或者插入用户的积分信息 //参数:STRU_ODBC_USER_GRADE& astruUserGradeInfo 用户的积分信息,bool abWholeValue //返回值: int ( 1 = 成功 // NORMAL_ERROR = 一般错误; CRITICAL_ERROR = 严重错误) //--------------------------------------------------------------------------------- int UpdateUserGrade(STRU_ODBC_USER_GRADE& astruUserGradeInfo,bool abWholeValue) { HSTMT l_hstmt; RETCODE li_ret = 0; char lc_sql_state[SQLSTATESIZE] = {0}; int li_result = 0; HENV l_henv; HDBC l_hdbc; DWORD ldw_object; USHORT lus_index; memset(lc_sql_state, 0, SQLSTATESIZE); l_hstmt = INVALID_HANDLE_VALUE; _try { /*ldw_object = WaitForMultipleObjects(giConnCount, gah_mutex[DEF_GAME_DB], FALSE, INFINITE); if (ldw_object < WAIT_OBJECT_0 || ldw_object >= WAIT_ABANDONED_0) { li_result = NORMAL_ERROR; _leave; } lus_index = (unsigned short)(ldw_object - WAIT_OBJECT_0); assert(lus_index < giConnCount); l_henv = ga_henv[DEF_GAME_DB][lus_index]; l_hdbc = ga_hdbc[DEF_GAME_DB][lus_index];*/ GET_DB_CONNECTION(l_henv, l_hdbc, DEF_GAME_DB, lus_index) li_ret = SQLAllocStmt(l_hdbc, &l_hstmt); if (li_ret != SQL_SUCCESS) { li_result = HandleODBCError(l_henv, l_hdbc, 0); _leave; } strcpy(lc_sql_state,"{call dbo.pr_update_user_grade(?,?,?,?,?,?,?,?,?,?) }"); // 捆绑输入参数 SQLBindParameter(l_hstmt, 1, SQL_PARAM_INPUT, SQL_C_UBIGINT, SQL_BIGINT, 0, 0, &astruUserGradeInfo.mbiUserId, 0, NULL); SQLBindParameter(l_hstmt, 2, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, GUID_STR_LEN, 0, astruUserGradeInfo.macPluginGuid, 0, NULL); SQLBindParameter(l_hstmt, 3, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &(astruUserGradeInfo.mlUserMark), 0, NULL); SQLBindParameter(l_hstmt, 4, SQL_PARAM_INPUT, SQL_C_SHORT , SQL_SMALLINT, 0, 0, &(astruUserGradeInfo.mwUserGrade), 0, NULL); SQLBindParameter(l_hstmt, 5, SQL_PARAM_INPUT, SQL_C_LONG , SQL_INTEGER, 0, 0, &(astruUserGradeInfo.mlWinCounts), 0, NULL); SQLBindParameter(l_hstmt, 6, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &(astruUserGradeInfo.mlLossCounts), 0, NULL); SQLBindParameter(l_hstmt, 7, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &(astruUserGradeInfo.mlEqualCounts), 0, NULL); SQLBindParameter(l_hstmt, 8, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &(astruUserGradeInfo.mlEscapeCounts), 0, NULL); SQLBindParameter(l_hstmt, 9, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_CHAR, NICK_NAME_LEN, 0, astruUserGradeInfo.macNicknm, 0, NULL); SQLBindParameter(l_hstmt, 10, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, &abWholeValue, 0, NULL); li_ret = SQLExecDirect(l_hstmt, (unsigned char *)lc_sql_state, SQL_NTS); if (li_ret != SQL_SUCCESS) { li_result = HandleODBCError(l_henv, l_hdbc, l_hstmt, lc_sql_state); SQLTransact(l_henv, l_hdbc, SQL_ROLLBACK); } else { SQLTransact(l_henv, l_hdbc, SQL_COMMIT); li_result = 1; } } _finally { if (l_hstmt != INVALID_HANDLE_VALUE) SQLFreeStmt(l_hstmt, SQL_DROP); //ReleaseMutex(gah_mutex[DEF_GAME_DB][lus_index]); RELEASE_DB_CONNECTION(l_henv, l_hdbc, DEF_GAME_DB, lus_index) return li_result; } }
发表评论
-
Berkeley DB 使用经验总结
2012-08-27 14:41 3087作者:陈磊 NoSQL是现在互联网Web2.0时代备受 ... -
嵌入式数据库系统Berkeley DB
2012-08-27 14:37 1534前言 UNIX/LINUX平台下的数据库种类非常多 ... -
C语言中标准输入流、标准输出流、标准错误输出流
2011-06-13 14:32 9295C语言中标准输入流、标准输出流、标准错误输出流 在 ... -
Rsync 实现原理
2011-05-12 20:06 8323Rsync 实现原理 前言 关于rsync的原始文档 ... -
c++简单的虚函数测试
2011-04-27 14:25 1022#include <iostream> u ... -
C++文件行查找
2011-04-26 14:10 1409#include <iostream> # ... -
c++偏特化简单示例
2011-04-13 11:17 2157c++偏特化 // temp1.c ... -
GDB调试精粹及使用实例
2011-03-16 14:06 1142GDB调试精粹及使用实例 一:列文件清单 1. ... -
简单的ini文件解析
2011-02-12 16:36 1624int GetKeyVal(const string s ... -
scanf族函数高级用法
2011-01-25 16:00 2563如何解释 fscanf(fd,&quo ... -
使用scons替代makefile(1)
2011-01-25 11:58 3735早在多年前我刚开始接触linux下的C程序时,经常被makef ... -
使用scons替代makefile(2)
2011-01-25 11:57 3585本篇文章接着上一篇进一步介绍scons的使用方法,主要介绍静态 ... -
使用scons替代makefile(3)
2011-01-25 11:55 4822在上两篇文章中已经简单介绍了用scons编译库文件,可执行程序 ... -
C 支持动态添加测试数据的测试代码
2011-01-13 17:22 1121/下面的定义为了支持可扩增。 //当需要增加一个新的测试用列 ... -
Linux下Makefile的automake生成
2010-12-28 16:55 1103******************helloworld.c* ... -
SCons笔记(详细版)
2010-12-23 16:11 105461. 基本使用 SConstruct文件就功能而言相当于Ma ... -
scons 学习
2010-12-23 11:14 2185scons 学习 作者:Sam(甄峰) sam_code@h ... -
scons随笔
2010-12-22 20:20 4709scons随笔 Scons是新一代的软件构件工具,或者说ma ... -
Scons在linux下的安装和使用
2010-12-21 11:59 3289因为正在用的一个开源软件需要的Developm ... -
排列组合的实现
2010-12-20 12:41 1066简单算法: 从前往后(或者从后往前)每次交换一个位置。当存在 ...
相关推荐
odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问存储过程/C++ odbc访问...
给了一个小的mysql 存储过程的例子。同时给出了一个在pb9中调用的例子.本例子是给出的mysql8.0的存储过程。对于5.7一下的现在odbc很难有支持
本报告详细介绍了使用ODBC(Open Database Connectivity)在数据库中进行编程的相关实验,包括了存储过程、触发器的创建和使用。ODBC是一种数据库访问技术,它允许应用程序通过标准化的方法连接不同的数据库管理系统...
### ODBC编程实例过程 #### 一、ODBC基础 ODBC(Open Database Connectivity)是微软公司在开放式服务架构中的一项关键技术,主要用于实现不同数据库管理系统之间的互操作性。它定义了一套标准API(Application ...
本篇文章将详细介绍如何利用ODBC获取Oracle连接,并通过存储过程和包来执行数据库操作。 首先,我们需要在操作系统上设置ODBC数据源。这通常通过“ODBC数据源管理器”完成,其中Windows用户可以在控制面板中找到这...
2. **特性**:提供完全的MySQL功能,包括事务处理、预编译语句、存储过程、长数据类型支持等。 3. **安全性**:通过ODBC驱动,用户可以设置安全的连接选项,如SSL加密,确保数据传输的安全。 4. **性能**:优化的...
本话题主要探讨的是如何在C++程序中使用Oracle数据库进行存储过程的批量插入操作。Oracle存储过程是预编译的SQL语句集合,它可以提高执行效率,减少网络通信,并且能够封装复杂的业务逻辑。 首先,我们需要理解C++...
1. 支持多种MySQL特性,如存储过程、触发器、视图等。 2. 提供了32位和64位版本,满足不同操作系统的需求。 3. 兼容MySQL服务器的多种版本,包括社区版和企业版。 4. 支持Unicode,可以处理多种语言的数据。 5. 支持...
这段代码演示了如何在AX 2009中创建一个ODBC连接,执行存储过程`SP_Test`,并处理返回的结果集。以下是一些关键点: 1. `ConnectionString`字符串包含了DSN(Data Source Name)、用户名和密码,用于标识要连接的...
### SQL Server 存储过程详解 #### 设计与创建存储过程 存储过程是SQL Server中预编译的一系列SQL语句,它们存储在数据库中,可通过名称调用,以执行特定任务。几乎任何Transact-SQL代码都可以用来创建存储过程,...
在实验中,虽然没有直接涉及ODBC编程,但我们可以推断,学生可能使用了支持ODBC的数据库工具或者编程语言(如C++或Java)来创建和执行这些存储过程和触发器。 【实验步骤与结果】 实验步骤涵盖了存储过程的创建、...
Ensemble(Cache)通过ODBC连接Mysql数据库并调用其存储过程。 web.test.mysql.DHCUser.cls的源代码.
4. **高级特性**: 支持高级SQL Server特性,如存储过程、事务处理、游标等。 **应用场景**: 1. **跨平台应用**: ODBC驱动允许Linux或macOS上的应用程序连接到运行在Windows上的SQL Server。 2. **数据分析工具**:...
1. **全面的SQL支持**:SQLite ODBC驱动能够执行完整的SQL92标准,包括复杂查询、子查询、事务处理和存储过程。 2. **高性能**:SQLite以其快速的查询处理和低内存占用而闻名,通过ODBC驱动,这些优点可以被充分...
同时,确保你的ODBC连接使用SSL加密,以防止数据在传输过程中被截获。 通过以上步骤,你应该能够解决"Call to undefined function odbc_connect"的问题,并成功建立PHP通过ODBC到数据库的连接。在处理这类问题时,...
此外,ODBC API支持存储过程的执行和参数的绑定。存储过程是数据库中执行特定操作的一系列SQL语句,它们通常用于提高性能和封装业务逻辑。ODBC通过SQLPrepare和SQLExecDirect函数支持SQL语句的准备和执行,这为动态...
在SQL Server 2000中,ODBC驱动程序支持多种特性,如事务处理、并发控制、游标、存储过程、预编译的SQL语句等。这些功能使得开发者能够实现复杂的数据库操作,如批量数据处理、复杂查询和应用级事务。 "访问我们的...
应确保数据传输过程中的加密,以及对用户凭据的安全存储。定期更新驱动和数据库服务器以获取最新的安全补丁也是必要的。 **8. 故障排查** 当遇到连接问题或错误时,ODBC驱动提供诊断信息,如错误代码和描述,帮助...