vc++使用odbc api连接数据库

2024-04-16 14:18

本文主要是介绍vc++使用odbc api连接数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

初次写博客,不知道效果怎样,我希望在这里,能和大家共同建立起一个交流平台,探讨技术

下面是我最近,做得事:使用odbc api 进行访问数据库,我这使用C++来编写的,希望对大家能有帮助

 

 

#include <windows.h>
#include <sql.h>
#include <sqlext.h>
#include <iostream.h>

int main()
{
 SQLHANDLE hEnv;
 SQLHANDLE hDBC;
 SQLHANDLE hSTMT;
 SQLRETURN retcode;
 SQLRETURN retcode_1;
 SQLCHAR pszId[30], pszName[30], pszTelephone[30];
 SQLINTEGER iName, iId, iTele;

 SQLAllocHandle(SQL_HANDLE_ENV, NULL, &hEnv);
 SQLSetEnvAttr(hEnv, SQL_ATTR_ODBC_VERSION,(SQLPOINTER) SQL_OV_ODBC3, SQL_IS_INTEGER);
 SQLAllocHandle(SQL_HANDLE_DBC,hEnv,&hDBC);

 try
 {
  retcode = SQLConnect(
   hDBC,
   (SQLCHAR*) "tomsky", SQL_NTS,
   (SQLCHAR*) "sa", SQL_NTS,
   (SQLCHAR*) "", SQL_NTS);
 }
 catch(...)
 {
  cout << "connecting is error!" << endl;
 }

 SQLAllocHandle(SQL_HANDLE_STMT,hDBC,&hSTMT);
 SQLCHAR sql[] = "select * from testTable;";
 
 try
 {
  retcode_1 = SQLExecDirect(hSTMT, sql, SQL_NTS);
 }
 catch(...)
 {
  cout << "execute sql error!" << endl;
 }

 while(SQL_NO_DATA != SQLFetch(hSTMT))
 {
  SQLGetData(hSTMT, 1, SQL_C_CHAR, pszId, 30, &iId);
  SQLGetData(hSTMT, 2, SQL_C_CHAR, pszName, 30, &iName);
  SQLGetData(hSTMT, 3, SQL_C_CHAR, pszTelephone, 30, &iTele);
  cout << "pszId:" << pszId << endl;
  cout << "pszName:" << pszName << endl;
  cout << "pszTelephone:" << pszTelephone << endl;
 }

 SQLFreeHandle(SQL_HANDLE_STMT, hSTMT);
 SQLFreeHandle(SQL_HANDLE_DBC, hDBC);
 SQLFreeHandle(SQL_HANDLE_ENV, hEnv);
 return 0;
}

如有疑问请大家多指教

这篇关于vc++使用odbc api连接数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/909020

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(