社区
应用实例
帖子详情
求高手指教:vs2008 c++怎么连接SQL Server数据库,实现数据的插入、删除等
沉默929
2014-07-21 02:43:47
vs2008 c++怎么连接SQL Server数据库,实现数据的插入、删除等??????????
...全文
577
3
打赏
收藏
求高手指教:vs2008 c++怎么连接SQL Server数据库,实现数据的插入、删除等
vs2008 c++怎么连接SQL Server数据库,实现数据的插入、删除等??????????
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
3 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
發糞塗牆
2014-07-21
打赏
举报
回复
VC++使用ADO连接SQL Server数据库 基本步骤: 1.创建一个基于对话框的应用程序ADODatabase。 2.创建一个用来连接的ADO类库。系统菜单中Insert->New Class项,class type选择Generic Class; 在Name后输入类名“ADOConn”,点OK。这样,在工程上自动生成ADOConn.h和ADOConn.cpp两个文件。 3.在ADOConn.h中导入一个ADO动态链接库msado15.dll,添加代码:#import "c:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","adoEOF") rename("BOF","adoBOF"),同时在ADOConn.h中定义 public://添加一个指向Connection对象的指针: _ConnectionPtr m_pConnection; //添加一个指向Recordset对象的指针: _RecordsetPtr m_pRecordset。 4.m_pConnection->Open(_bstr_t ConnectionString, _bstr_t UserID, _bstr_t Password, long Options) 操作。ConnectionString为VC++中对SQL SERVER中ADO设置。如,Provider=SQLOLEDB;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=suntest;Data Source=WWW-ED1F301E78B ;User Id=sa;Password=; 其中Data Source为服务器名称,可以用Server代替,本机表示为.或者(local);Initial Catalog为你要使用的数据库名称可以用Database代替;Integrated Security=SSPI表示用集成模式,此时uid 和pwd 设置不起作用;只有当Integrated Security=FALSE表示用混合模式,uid 和pwd 设置才起作用 参数Options表示CommandText的类型:adCmdText-文本命令;adCmdTable-表名 adCmdProc-存储过程;adCmdUnknown-未知 5.添加两个成员函数:(1)执行查询函数 _RecordsetPtr& GetRecordSet(_bstr_t bstrSQL);(2)执行SQL语句 BOOL ExecuteSQL(_bstr_t bstrSQL)。 给出两个文件的完整代码: // ADOConn.h: interface for the ADOConn class. #import "c:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","adoEOF") rename("BOF","adoBOF") #if !defined(AFX_ADOCONN_H__AC448F02_AF26_45E4_9B2D_D7ECB8FFCFB9__INCLUDED_) #define AFX_ADOCONN_H__AC448F02_AF26_45E4_9B2D_D7ECB8FFCFB9__INCLUDED_ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 class ADOConn { // 定义变量 public: //添加一个指向Connection对象的指针: _ConnectionPtr m_pConnection; //添加一个指向Recordset对象的指针: _RecordsetPtr m_pRecordset; // 定义方法 public: ADOConn(); virtual ~ADOConn(); // 初始化—连接数据库 void OnInitADOConn(); // 执行查询 _RecordsetPtr& GetRecordSet(_bstr_t bstrSQL); // 执行SQL语句,Insert Update _variant_t BOOL ExecuteSQL(_bstr_t bstrSQL); void ExitConnect(); }; #endif // !defined(AFX_ADOCONN_H__AC448F02_AF26_45E4_9B2D_D7ECB8FFCFB9__INCLUDED_) #include "stdafx.h" #include "ADOConn.h" #ifdef _DEBUG #undef THIS_FILE static char THIS_FILE[]=__FILE__; #define new DEBUG_NEW #endif ADOConn::ADOConn() { } ADOConn::~ADOConn() { } // 初始化—连接数据库 void ADOConn::OnInitADOConn() { // 初始化OLE/COM库环境 ::CoInitialize(NULL); try { // 创建Connection对象 m_pConnection.CreateInstance("ADODB.Connection"); // 设置连接字符串,必须是BSTR型或者_bstr_t类型 _bstr_t strConnect = "Provider=SQLOLEDB; Server=CZ;Database=HrSys; uid=sa; pwd=sa;"; m_pConnection->Open(strConnect,"","",adModeUnknown); } // 捕捉异常 catch(_com_error e) { // 显示错误信息 AfxMessageBox(e.Description()); } } // 执行查询 _RecordsetPtr& ADOConn::GetRecordSet(_bstr_t bstrSQL) { try { // 连接数据库,如果Connection对象为空,则重新连接数据库 if(m_pConnection==NULL) OnInitADOConn(); // 创建记录集对象 m_pRecordset.CreateInstance(__uuidof(Recordset)); // 取得表中的记录 m_pRecordset->Open(bstrSQL,m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText); } // 捕捉异常 catch(_com_error e) { // 显示错误信息 AfxMessageBox(e.Description()); } // 返回记录集 return m_pRecordset; } // 执行SQL语句,Insert Update _variant_t BOOL ADOConn::ExecuteSQL(_bstr_t bstrSQL) { // _variant_t RecordsAffected; try { // 是否已经连接数据库 if(m_pConnection == NULL) OnInitADOConn(); // Connection对象的Execute方法:(_bstr_t CommandText, // VARIANT * RecordsAffected, long Options ) // 其中CommandText是命令字串,通常是SQL命令。 // 参数RecordsAffected是操作完成后所影响的行数, // 参数Options表示CommandText的类型:adCmdText-文本命令;adCmdTable-表名 // adCmdProc-存储过程;adCmdUnknown-未知 m_pConnection->Execute(bstrSQL,NULL,adCmdText); return true; } catch(_com_error e) { AfxMessageBox(e.Description()); return false; } } void ADOConn::ExitConnect() { // 关闭记录集和连接 if (m_pRecordset != NULL) m_pRecordset->Close(); m_pConnection->Close(); // 释放环境 ::CoUninitialize(); }
--小F--
2014-07-21
打赏
举报
回复
说得好笼统啊 可以用ODBC,也可以用ADO
http://blog.csdn.net/dlutxie/article/details/6849385
估计需要去下载一些驱动
shoppo0505
2014-07-21
打赏
举报
回复
c++中也有SQL类库吧? 定义SQLConnection 和SQLCommand就能操作SQL数据库了。
C++
控制台程序使用ODBC
连接
SQL
Server
连接
: 一、设置ODBC的
数据
源 二、进行代码
连接
总流程: 1、申请环境句柄 2、配置环境句柄 3、申请
连接
句柄 4、定义
数据
库
名、用户名、用户密码 5、
连接
数据
库
,并验证是否
连接
成功 6、申请语句句柄 7...
SQL
Server
创建库,表步骤和基本操作语句
SQL
Server
2012创建库步骤和相关基本操作语句:
VS
2015
连接
my
SQL
数据
库
VS
2015
连接
my
SQL
数据
库
如题,今天给大家简单演示一下
VS
2015如何
连接
my
SQL
数据
库
。 首先呢,大家需要安装
vs
2015和my
SQL
这两个软件,我还安装了一个辅助软件
SQL
yog - 32 bit(我师兄推荐我安装的),还有...
图书管理系统(C &
SQL
)
开发一个图书管理系统,该系统结合My
SQL
数据
库
设计而构成的一个
数据
库
管理系统,对图书信息进行添加、
删除
、修改、查询等操作。
实现
功能: 录入图书信息
实现
删除
功能
实现
查找功能
实现
修改功能 保存添加的...
SQL
Server
中关于基数估计如何计算预估行数的一些探讨
原文:
SQL
Server
中关于基数估计如何计算预估行数的一些探讨 关于
SQL
Server
2014中的基数估计,官方文档Optimizing Your Query Plans with the
SQL
Server
2014 Cardinality Estimator里有大量细节介绍,但是全部是...
应用实例
27,579
社区成员
68,558
社区内容
发帖
与我相关
我的任务
应用实例
MS-SQL Server 应用实例
复制链接
扫一扫
分享
社区描述
MS-SQL Server 应用实例
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章