视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
ADO方式操作ACCESS数据库
2020-11-09 07:19:35 责编:小采
文档


欢迎进入C/C++编程社区论坛,与200万技术人员互动交流 >>进入 (1)通过JET数据库引擎对ACCESS2000数据库的连接: m_pConnection-Open(\"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\\\\test.mdb\",\"\",\"\",adModeUnknown); (2)通过DSN数据源对任

欢迎进入C/C++编程社区论坛,与200万技术人员互动交流 >>进入



  (1)通过JET数据库引擎对ACCESS2000数据库的连接:

m_pConnection->Open(\"Provider=Microsoft.Jet.OLEDB.4.0;
Data Source=C:\\\\test.mdb\",\"\",\"\",adModeUnknown);

  (2)通过DSN数据源对任何支持ODBC的数据库进行连接:

m_pConnection->Open(\"Data Source=adotest;UID=sa;PWD=;\",\"\",\"\",adModeUnknown);

  (3)不通过DSN对SQL SERVER数据库进行连接:

m_pConnection->Open(\"driver={SQL Server};Server=127.0.0.1;DATABASE=vckbase;
UID=sa;PWD=139\",\"\",\"\",adModeUnknown);

  其中Server是SQL服务器的名称,DATABASE是库的名称。

  Connection对象除Open()方法外还有许多方法,我们先介绍Connection对象中两个有用的属性ConnectionTimeOut与State。ConnectionTimeOut用来设置连接的超时时间,需要在Open之前调用,例如:

m_pConnection->ConnectionTimeout = 5;///设置超时时间为5秒
m_pConnection->Open(\"Data Source=adotest;\",\"\",\"\",adModeUnknown);


  State属性指明当前Connection对象的状态,0表示关闭,1表示已经打开,我们可以通过读取这个属性来作相应的处理,例如:

if(m_pConnection->State)
m_pConnection->Close(); ///如果已经打开了连接则关闭它

  4、执行SQL命令并取得结果记录集

  为了取得结果记录集,我们定义一个指向Recordset对象的指针:_RecordsetPtr m_pRecordset;

  并为其创建Recordset对象的实例: m_pRecordset.CreateInstance(\"ADODB.Recordset\"),SQL命令的执行可以采用多种形式,下面我们一一进行阐述。

  (1)利用Connection对象的Execute方法执行SQL命令

  Execute()方法的原型如下所示:

_RecordsetPtr Connection15::Execute ( _bstr_t CommandText, VARIANT * RecordsAffected, long Options )

  其中CommandText是命令字串,通常是SQL命令。参数RecordsAffected是操作完成后所影响的行数, 参数Options表示CommandText中内容的类型,Options可以取如下值之一:adCmdText表明CommandText是文本命令;adCmdTable表明CommandText是一个表名;adCmdProc表明CommandText是一个存储过程;adCmdUnknown表明CommandText内容未知。Execute()函数执行完后返回一个指向记录集的指针,下面我们给出具体代码并作说明:

_variant_t RecordsAffected;
///执行SQL命令:CREATE TABLE创建表格users,users包含四个字段:整形ID,字符串username,整形old,日期型birthday
m_pConnection->Execute(\"CREATE TABLE users(ID INTEGER,username
TEXT,old INTEGER,birthday DATETIME)\",&RecordsAffected,adCmdText);
///往表格里面添加记录
m_pConnection->Execute(\"INSERT INTO users(ID,username,old,birthday)
VALUES (1, \'Washington\',25,\'1970/1/1\')\",&RecordsAffected,adCmdText);
///将所有记录old字段的值加一
m_pConnection->Execute(\"UPDATE users SET old = old+1\",&RecordsAffected,adCmdText);
///执行SQL统计命令得到包含记录条数的记录集
m_pRecordset = m_pConnection->Execute(\"SELECT COUNT(*) FROM
users\",&RecordsAffected,adCmdText);
_variant_t vIndex = (long)0;
_variant_t vCount = m_pRecordset->GetCollect(vIndex);///取得第一个字段的值放入vCount变量
m_pRecordset->Close();///关闭记录集
CString message;
message.Format(\"共有%d条记录\",vCount.lVal);
AfxMessageBox(message);///显示当前记录条数

  (2)利用Command对象来执行SQL命令

_CommandPtr m_pCommand;
m_pCommand.CreateInstance(\"ADODB.Command\");
_variant_t vNULL;
vNULL.vt = VT_ERROR;
vNULL.scode = DISP_E_PARAMNOTFOUND;///定义为无参数
m_pCommand->ActiveConnection = m_pConnection;///非常关键的一句,将建立的连接赋值给它
m_pCommand->CommandText = \"SELECT * FROM users\";///命令字串
m_pRecordset = m_pCommand->Execute(&vNULL,&vNULL,adCmdText);
//执行命令取得记录集

  在这段代码中我们只是用Command对象来执行了SELECT查询语句,Command对象在进行存储过程的调用中能真正体现它的作用。下次我们将详细介绍。

[1] [2] [3]

下载本文
显示全文
专题