鱼C论坛

 找回密码
 立即注册
查看: 1551|回复: 1

c++ ado 访问SQL的空表问题

[复制链接]
发表于 2015-6-10 12:29:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
测试C++ ADO 访问修改SQL数据的时候 发现表内数据为空的时候会报指针的错误.下面上图片和上代码
#include <icrsint.h>
#include<iostream>
#include<iomanip>
#include <string>

#import "c:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF", "adoEOF") rename("BOF", "adoBOF")


class cSQL
{
public:
        cSQL()
        {
                CoInitialize(NULL);
                HRESULT hr = sqlSp.CreateInstance(__uuidof(Connection));
                if (FAILED(hr))
                {
                        std::cout << "初始化指针失败!" << std::endl;
                        return;
                }
                else
                {                
                        if (FAILED(m_pRecordset.CreateInstance(_uuidof(Recordset))))
                        {
                                std::cout << "记录集对象指针实例化失败!" << std::endl;
                                return;
                        }
                }
        }
        ~cSQL()
        {

                m_pRecordset->Close();
                sqlSp->Close();
                CoUninitialize();
        }

        void INIT(char password[])
        {
                sprintf_s(bueffer, 256, "Driver={sql server};server=127.0.0.1,1433;uid=sa;pwd=%s;database=wx2008db;", password);
                _bstr_t strConnect = bueffer;

                try
                {                        
                        sqlSp->Open(strConnect, "", "", NULL);
                }
                catch (_com_error &e)
                {
                        std::cout << e.Description() << std::endl;
                }

                try
                {
                        m_pRecordset->Open("select * from  tStat", (IDispatch*)sqlSp, adOpenDynamic, adLockOptimistic, adCmdText);
                }
                catch (_com_error &e)
                {
                        std::cout << e.Description() << std::endl;
                }

                try
                {
                        m_pRecordset->MoveFirst();
                        while (!m_pRecordset->adoEOF)   ////遍历并读取sPassword列的记录并输出   直到结尾 
                        {
                                insertTime = (char *)(_bstr_t)m_pRecordset->GetCollect("sCardID");//方法一;
                                //m_pRecordset->Fields->GetItem(_variant_t("sCardID"))->Value);
                                std::cout << "\t" << insertTime << std::endl;
                                m_pRecordset->MoveNext();


                        }
                }
                catch (_com_error &e)
                {
                        std::cout << e.Description()<< std::endl;
                }

        }
protected:
        _ConnectionPtr  sqlSp=NULL;
        _RecordsetPtr        m_pRecordset;
        char bueffer[256], serverip[256], password[256];
        std::string insertTime;

};


void main()
{
        cSQL mysql;
        mysql.INIT("Sicent110");
        system("pause");
}

谁能看下要怎么改呢

读取到空数据时报错

读取到空数据时报错

数据的查看

数据的查看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-6-10 20:29:59 | 显示全部楼层
难道没有悬赏没有人出手?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 01:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表