最近在用ADO访问Access数据库的时候出现了一个奇怪的错误,觉得有必要记录下来,和大家分享一下。

  1. 环境
    1. win7 x86系统;

    2. VS2012编译器;

    3. Office2010;

    4. Access2000~Access2003连接串建立数据库连接。

  2. 关键数据库操作代码
    1. BOOL CAccessDatabase::Query(const CString strSQLString, UINT nFieldNumber, vector<vector<_variant_t> >& vecvecVariant)
      {
      _variant_t Variant;
      vector<_variant_t> vecVariant; EnterCriticalSection(&m_cs); _RecordsetPtr pRecordset = NULL;
      HRESULT hr = S_FALSE;
      try
      {
      hr = pRecordset.CreateInstance(_T("ADODB.Recordset"));
      if (SUCCEEDED(hr))
      {
      hr = pRecordset->Open(strSQLString.AllocSysString(), m_pConnection.GetInterfacePtr(), adOpenDynamic, adLockOptimistic, adCmdText);
      if (SUCCEEDED(hr))
      {
      if (!pRecordset->adoEOF)
      {
      hr = pRecordset->MoveFirst();
      if (SUCCEEDED(hr))
      {
      while (!(pRecordset->adoEOF))
      {
      vecVariant.clear();
      for (UINT i = ; i < nFieldNumber; ++i)
      {
      ZeroMemory(&Variant, sizeof(Variant));
      Variant = pRecordset->GetCollect(_variant_t((long)i));
      vecVariant.push_back(Variant);
      }
      vecvecVariant.push_back(vecVariant); hr = pRecordset->MoveNext();
      }
      }
      else
      {
      m_pLogFile->WriteLog(GetLastError(), _T("移动记录集指针到首部发生错误")); if (pRecordset->GetState() != adStateClosed)
      {
      hr = pRecordset->Close();
      if (FAILED(hr))
      {
      m_pLogFile->WriteLog(GetLastError(), _T("关闭记录集失败"));
      }
      else
      {
      m_pLogFile->WriteLog(GetLastError(), _T("记录集已关闭"));
      }
      } if (pRecordset != NULL)
      {
      pRecordset.Release();
      pRecordset = NULL;
      }
      LeaveCriticalSection(&m_cs);
      return FALSE;
      }
      }
      else
      {
      m_pLogFile->WriteLog(GetLastError(), _T("查询的记录集为空"));
      }
      }
      else
      {
      m_pLogFile->WriteLog(GetLastError(), _T("打开记录集失败")); if (pRecordset != NULL)
      {
      pRecordset.Release();
      pRecordset = NULL;
      }
      LeaveCriticalSection(&m_cs);
      return FALSE;
      }
      }
      else
      {
      m_pLogFile->WriteLog(GetLastError(), _T("初始化记录集失败")); pRecordset = NULL;
      LeaveCriticalSection(&m_cs);
      return FALSE;
      }
      }
      catch (_com_error e)
      {
      m_pLogFile->WriteLog(e.ErrorMessage());
      AfxMessageBox(e.ErrorMessage());
      LeaveCriticalSection(&m_cs);
      return FALSE;
      } if (pRecordset->GetState() != adStateClosed)
      {
      try
      {
      hr = pRecordset->Close();
      if (FAILED(hr))
      {
      m_pLogFile->WriteLog(GetLastError(), _T("关闭记录集失败"));
      }
      else
      {
      m_pLogFile->WriteLog(GetLastError(), _T("记录集已关闭"));
      }
      }
      catch (_com_error err)
      {
      m_pLogFile->WriteLog(err.ErrorMessage());
      AfxMessageBox(err.ErrorMessage());
      }
      } if (pRecordset != NULL)
      {
      pRecordset.Release();
      pRecordset = NULL;
      } LeaveCriticalSection(&m_cs); return TRUE;
      }
  3. 数据库调用代码
    1.     if (!Database.Query(_T("select ZoneName from Zone"), , vecvecZone))
      {
      LogFile.WriteLog(GetLastError(), _T("从数据库中获取客户端名称失败"));
      AfxMessageBox(_T("从数据库中获取客户端名称失败"));
      return;
      }
  4. 错误问题
    1. 程序在Query里面产生了异常。在调用pRecordset->Open(...)的时候产生了异常,异常错误信息是“未指定的错误”;
    2. 将调用的Sql语句放到Access数据库中可以正确执行。
  5. 解决办法
    1. 将数据库的表名"Zone"修改为"MyZone"等其它名称即可。
  6. 总结
    1. 在编程访问Access数据库时表名不能为"Zone"。
  7. 代码上传
    1. 下载连接:http://pan.baidu.com/s/1mgFlOqk

ADO访问Access数据库错误解决心得随笔的更多相关文章

  1. x64 win64编译环境下ADO链接Access数据库的问题解决

    原文链接地址:https://blog.csdn.net/HW140701/article/details/71077579 Win32编译环境下,用ADO数据库连接Access数据库一般都不会报错, ...

  2. ADO访问Oracle数据库,连接异常(Unknown error 0x800a0e7a)

    ADO访问Oracle数据库,连接异常(Unknown error 0x800a0e7a) 代码如下:执行Open过程中出现异常,信息为Unknown error 0x800a0e7a  C++ Co ...

  3. C#.NET ORM 如何访问 Access 数据库 [FreeSql]

    最近很多 .net QQ 群无故被封停,特别是 wpf 群几乎全军覆没.依乐祝的 .net6交流群,晓晨的 .net跨平台交流群,导致很多码友流离失所无家可归,借此机会使用一次召唤术,有需要的请加群: ...

  4. [转载]Unity3D 访问Access数据库

    在开始这个小教程之前呢,其实在网上你已经可以找到相关的资料了,但是我还是要把我自己做练习的一点东西分享出来.写这个教程的主要原因呢,是一个朋友在u3d的官网论坛里,找到了这个demo,但是在他使用的过 ...

  5. Excel中使用VBA访问Access数据库

    VBA访问Access数据库 1. 通用自动化语言VBA VBA(Visual Basic For Application)是一种通用自动化语言,它可以使Excel中的常用操作自动化,还可以创建自定义 ...

  6. Unity访问Access数据库

    首先,准备工作: 创建一个Access 数据库,命名AccessTest.accdb,添加一些数据用于测试 准备System.Data.dll与System.EnterpriseServices.dl ...

  7. 如何使用.net访问Access数据库 (转)

    前言:今天整理程序,看到之前写的一个Demo,也不知道是从哪里参考的了,写到这里,留作备用吧. 使用.net访问Access数据库:1.BL层:新增一个DataAccess类. Code].Defau ...

  8. php连接Access数据库错误及解决方法

    <?php $connstr="DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" . realpath("data.m ...

  9. MFC通过ADO操作Access数据库

    我在<VC知识库在线杂志>第十四期和第十五期上曾发表了两篇文章——“直接通过ODBC读.写Excel表格文件”和“直接通过DAO读.写Access文件”,先后给大家介绍了ODBC和DAO两 ...

随机推荐

  1. ylbtech-LanguageSamples-Yield

    ylbtech-Microsoft-CSharpSamples:ylbtech-LanguageSamples-Yield 1.A,示例(Sample) 返回顶部 “Yield”示例 本示例演示如何创 ...

  2. 跨浏览器复制神器 ZeroClipboard 2.x快速入门详解

    有些时候,我们希望让用户在网页上完成某个操作就能自动将指定的内容复制到用户计算机的剪贴板中.但是出于安全原因,大多数现代浏览器都未提供通用的剪贴板复制接口(或即便有,也默认被禁用).只有IE浏览器可以 ...

  3. Redis中7种集合类型应用场景&redis常用命令

    Redis常用数据类型 Redis最为常用的数据类型主要有以下五种: String Hash List Set Sorted set 在具体描述这几种数据类型之前,我们先通过一张图了解下Redis内部 ...

  4. android 定时执行一个任务

    1. timer = new Timer(true) TimerTask task =  new TimerTask(){ public void run(){ test(); } } timer.s ...

  5. [ActionScript&Flex] FlashBuilder编译条件之如何屏蔽调试代码

    下面讲一下在FlashBuilder中如何添加编译器参数使我们在发布的时候不编译调试代码: 首先设置编译参数 编译参数设置好后,代码我们可以这样写: public class ConditionalC ...

  6. nyoj 102 次方求摸 快速幂

    点击打开链接 次方求模 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描述 求a的b次方对c取余的值 输入 第一行输入一个整数n表示测试数据的组数(n<100) 每组测 ...

  7. (medium)LeetCode 230.Kth Smallest Element in a BST

    Given a binary search tree, write a function kthSmallest to find the kth smallest element in it. Not ...

  8. Android--Intent的使用

    1.Activity之间的切换通过Intent来完成. 1)清单文件,配置好Activity,所有Activity都需要在该文件中配置. <?xml version="1.0" ...

  9. Eclipse不能进入断点

    如题:Eclipse不能进入断点,可能是项目没有build,如果是maven项目,clean,在maven install就可以了

  10. JAVA设计模式之调停者模式

    在阎宏博士的<JAVA与模式>一书中开头是这样描述调停者(Mediator)模式的: 调停者模式是对象的行为模式.调停者模式包装了一系列对象相互作用的方式,使得这些对象不必相互明显引用.从 ...