各位大佬,请问一下:VC++6.0编译时没错误,但是运行不了是因为什么啊,都是照着书编的! 20C

BOOL CRentDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// Add "About..." menu item to system menu.

// IDM_ABOUTBOX must be in the system command range.
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);

CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
    CString strAboutMenu;
    strAboutMenu.LoadString(IDS_ABOUTBOX);
    if (!strAboutMenu.IsEmpty())
    {
        pSysMenu->AppendMenu(MF_SEPARATOR);
        pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
    }
}

// Set the icon for this dialog.  The framework does this automatically
//  when the application's main window is not a dialog
SetIcon(m_hIcon, TRUE);         // Set big icon
SetIcon(m_hIcon, FALSE);        // Set small icon

// TODO: Add extra initialization here
//初始化List控件的栏目名,设置List控件每列的标题、宽度
m_rentInfoList.InsertColumn(0,"ID",LVCFMT_LEFT,40,-1);
m_rentInfoList.InsertColumn(1,"租借人",LVCFMT_LEFT,160,-1);
m_rentInfoList.InsertColumn(2,"租借DVD名",LVCFMT_LEFT,200,-1);
m_rentInfoList.InsertColumn(3,"租借日期",LVCFMT_LEFT,160,-1);
//设置List的行被选中时是全行选中
m_rentInfoList.SetExtendedStyle(LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES);
//设置Date Time Picker控件的日期格式
m_DateFrom.SetFormat("yyyyMMdd");
m_DateTo.SetFormat("yyyyMMdd");
//日期查询初始化时是不选中的,设置起始日期的控件不可用
m_check_Date=FALSE;
m_DateFrom.EnableWindow(FALSE);
m_DateTo.EnableWindow(FALSE); 
//初始化数据库连接
HRESULT  hr;
try
{
    //实例化连接对象
    hr=m_pConnection.CreateInstance(__uuidof(Connection));
    if(SUCCEEDED(hr))
    {
        //设置连接串属性为UDL文件
         m_pConnection->ConnectionString="File Name=my_data1.udl";
         //设置等待连接打开的时间为20秒
          m_pConnection->ConnectionTimeout=20;
          hr=m_pConnection->Open ("","","",NULL);
          if(FAILED(hr))
          {
              AfxMessageBox("open fail!");
              return TRUE;
          }
    }
    else
    {
              AfxMessageBox("createinstance of Connection fail!");
              return TRUE;
    }
} 
catch(_com_error e)
{//给出异常信息
    _bstr_t bstrSource(e.Source ());
    _bstr_t bstrDescription(e.Description());
    AfxMessageBox(bstrSource+bstrDescription);
    return TRUE;
}
//获得本月的出租记录,并显示在List控件中
InitListCtr();
return TRUE;  // return TRUE  unless you set the focus to a control

}

void CRentDlg::OnCheckDate()
{
// TODO: Add your control notification handler code here
if(m_check_Date==FALSE)
{
m_check_Date=TRUE;
m_DateFrom.EnableWindow(TRUE);
m_DateTo.EnableWindow(TRUE);
}
else
{ m_check_Date=FALSE;
m_DateFrom.EnableWindow(FALSE);
m_DateTo.EnableWindow(FALSE);
}
}

void CRentDlg::InitListCtr()
{
HRESULT hr;
//定义记录集指针
RecordsetPtr pRentRecordset;
//实例化记录集指针
hr=pRentRecordset.CreateInstance(
_uuidof(Recordset));
//判断创建记录集指针实例是否成功
if(FAILED(hr))
{
AfxMessageBox("createinstance of Recordset fail!\n can't initiate List control!");
return;
}
//定义字符串存储SQL语句
CString strSql;
//定义_variant_t变量存储从数据库读取到的字段
_variant_t var;
//定义字符串存储_varient_t变量中的字符串
CString strValue;
//List控件中记录的序号
int curItem=0;
//初始化SQL语句字符串,获得tbRentInfo表中的
strSql="SELECT * FROM tbRentInfo";
try
{//利用Open函数执行SQL命令,获得查询结果记录集
//需要把CString类型转化为_varient_t类型
hr=pRentRecordset->Open (_variant_t(strSql),
m_pConnection.GetInterfacePtr(),
adOpenDynamic,
adLockOptimistic,
adCmdText);
if(SUCCEEDED(hr))
{//判断记录集是否到末尾,对每条记录,把字段插入List控件的每一行中
while(!pRentRecordset->adoEOF)
{//获得记录集中但前记录的第一个字段的值
var = pRentRecordset->GetCollect((long)0);
if(var.vt != VT_NULL)
strValue = (LPCSTR)_bstr_t(var);
//插入该字符串到List控件中
m_rentInfoList.InsertItem(curItem,strValue);
//获得记录集中但前记录的"Name"字段的值
var = pRentRecordset->GetCollect("Name");
if(var.vt != VT_NULL);
strValue = (LPCSTR)_bstr_t(var);
m_rentInfoList.SetItemText(curItem,1,strValue);

               var = pRentRecordset->GetCollect("DVDID");

               if(var.vt != VT_NULL);
                   strValue = (LPCSTR)_bstr_t(var);
                   //需要根据该DVDID查询tbDVDInfo,获得DVDname,插入List控件中
              m_rentInfoList.SetItemText(curItem,2,QueryDVDName(strValue));

              var = pRentRecordset->GetCollect("Date");
              if(var.vt != VT_NULL);
                   strValue = (LPCSTR)_bstr_t(var);
            m_rentInfoList.SetItemText(curItem,3,strValue);
            //移动当前记录到下一条记录
            pRentRecordset->MoveNext();
            curItem++;
           }
       }
       else
       {
           AfxMessageBox("Open recordset fail!");
       }
       }
       catch(_com_error *e)
       {
           AfxMessageBox( e->ErrorMessage());
           return;
       }
       pRentRecordset->Close();
       pRentRecordset=NULL;

}

CString CRentDlg::QueryDVDName(CString DVDID)
{
RecordsetPtr pDVDNameRecordset;
pDVDNameRecordset.CreateInstance(
_uuidof(Recordset));
CString strValue;
_variant_t var;
//直接使用_bstr_t类型的字符串
_bstr_t vSQL;
//选择参数指定的DVDID的记录
vSQL="select DVDNme from tbDVDInfo where DVDID="+DVDID;
try
{//vSQL可以直接作为参数传给Open函数,而如果使用CStrig类型需要类型转换
HRESULT hr;
//利用SQL语句打开记录集
hr=pDVDNameRecordset->Open(vSQL,
m_pConnection.GetInterfacePtr(),
adOpenDynamic,
adLockOptimistic,
adCmdText);
if(!FAILED(hr))
{
var=pDVDNameRecordset->GetCollect("DVDName");
if(var.vt != VT_NULL);
strValue = (LPCSTR)_bstr_t(var);
}
else strValue="";
}
catch(_com_error *e)
{
AfxMessageBox(e->ErrorMessage());
strValue="";

 }
 pDVDNameRecordset->Close();
 pDVDNameRecordset=NULL;
 return strValue;

}
这些是我加的除了添加成员函数和成员变量以外的程序,应该怎么改啊

3个回答

m_pConnection->ConnectionString="File Name=my_data1.udl";
你的odbc怎么配置的。

简单的就是单步看看走到哪里出错。。。不然看代码很难看出来。。。

 m_rentInfoList.InsertColumn(0,"ID",LVCFMT_LEFT,40,-1);  //断点到这里 F5 开始单步调试

我是用udl文件通过ado方式连得
F5直接跳出说abnormal program teimination

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
各位大佬,请问一下:VC++6.0编译时没错误,但是运行不了是因为什么啊,都是照着书编的!
-
求助mfc大佬,vc6.0如何使文本编辑框在窗体中居中?
-
使用七牛云上传图片,在测试类中测试文件上传,报出Caused by: java.lang.ClassNotFoundException: okhttp3.Interceptor错误
-
AS创建新项目报错java.util.concurrent.ExecutionException: org.apache.http.conn.ConnectTimeoutException
-
Android Studio 编译项目突然报错 Unsupported manifest version: 7.0.1.7829.
-
javaweb报 No suitable driver found for jdbc:mysql:/.....错误
-
遇到Program type already present: android.support.v4.app.BackStackRecord$Op这个问题
-
同时安装vc6.0和vs2008是不是会矛盾不兼容?
-
小白,想用Python3.7+Opencv4.1.1+APP:IP摄像头,调用手机的摄像头。 结果出现如下状况,还请各位大佬指点!
-
org.springframework.web.context.ConfigurableWebApplicationContext.setId(Ljava/lang/String;)V
-
各位大佬们,我用three.js来展现3d模型到网页上,但是每次调用OrbitControls.js控制器里面的addEventListener都是出现错误,不知道怎样解决,急急急,求助
-
struts2.5启动保错如下请问大佬们怎么解决?
-
Tomcat ClassNotFoundException: java.util.logging.Logger
-
为什么Opencv3.4.0使用make编译时出现错误?
-
JAVA 给JVM 注册CA证书之后 仍然出现证书不信任问题。
-
webpack4.0中引入app.vue出现报错
-
JDBC驱动加载失败,异常:java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
-
flume开启报错java.lang.SecurityException: sealing violation: package org.apache.flume.conf is sealed
-
Elasticsearch.bat改了yml配置重启报错直接闪退出命令行
-
学会了这些技术,你离BAT大厂不远了
每一个程序员都有一个梦想,梦想着能够进入阿里、腾讯、字节跳动、百度等一线互联网公司,由于身边的环境等原因,不知道 BAT 等一线互联网公司使用哪些技术?或者该如何去学习这些技术?或者我该去哪些获取这些技术资料?没关系,平头哥一站式服务,上面统统不是问题。平头哥整理了 BAT 等一线大厂的必备技能,并且帮你准备了对应的资料。对于整理出来的技术,如果你掌握的不牢固,那就赶快巩固,如果你还没有涉及,现在...
程序员实用工具网站
目录 1、搜索引擎 2、PPT 3、图片操作 4、文件共享 5、应届生招聘 6、程序员面试题库 7、办公、开发软件 8、高清图片、视频素材网站 9、项目开源 10、在线工具宝典大全 程序员开发需要具备良好的信息检索能力,为了备忘(收藏夹真是满了),将开发过程中常用的网站进行整理。 1、搜索引擎 1.1、秘迹搜索 一款无敌有良心、无敌安全的搜索引擎,不会收集私人信息,保...
程序员真是太太太太太有趣了!!!
网络上虽然已经有了很多关于程序员的话题,但大部分人对这个群体还是很陌生。我们在谈论程序员的时候,究竟该聊些什么呢?各位程序员大佬们,请让我听到你们的声音!不管你是前端开发...
史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)
网上很多整合SSM博客文章并不能让初探ssm的同学思路完全的清晰,可以试着关掉整合教程,摇两下头骨,哈一大口气,就在万事具备的时候,开整,这个时候你可能思路全无 ~中招了咩~ ,还有一些同学依旧在使用eclipse或者Myeclipse开发,我想对这些朋友说IDEA 的编译速度很快,人生苦短,来不及解释了,直接上手idea吧。这篇文章每一步搭建过程都测试过了,应该不会有什么差错。本文章还有个比较优秀的特点,就是idea的使用,基本上关于idea的操作都算是比较详细的,所以不用太担心不会撸idea!最后,本文
我的 Input框 不可能这么可爱
作者:陈大鱼头 github: KRISACHAN &lt;input /&gt; 标签是我们日常开发中非常常见的替换元素了,但是最近在刷 whattwg 跟 MDN 的时候发现 跟 &lt;input /&gt; 有很多相关的属性,选择器都没怎么用过,所以就开篇文章来整理一下一些比较有趣或者实用的知识点。 本篇文章默认大家已经知道 &lt;input /&gt; 标签的基本用法,不会做过...
一声令下即可关灯,再也不用在寒冬深夜离开被窝~
全文共2951字,预计学习时长6分钟 你有没有在大冬天里的深夜里,为了关灯睡觉而不得不离开温暖被窝的经历? 本文将介绍如何为普通家庭照明开关构建自然语言接口,以便用户可以使用如“请打开所有灯”或者“打开孩子房间里的灯”等简单命令来控制灯光。 本文主要介绍自然语言接口(NLI)部分,不涵盖语音识别与实际灯光操作部分。你可以使用WebSpeech轻易实现语音转换,如有所需,也可使用Ardui...
知乎上 40 个有趣回复,很精辟很提神
点击蓝色“五分钟学算法”关注我哟加个“星标”,天天中午 12:15,一起学算法作者 |佚名来源 |网络整理,版权归原作者所有,侵删。1交朋友的标准是什么?- Ques...
从入门到精通,Java学习路线导航
引言 最近也有很多人来向我"请教",他们大都是一些刚入门的新手,还不了解这个行业,也不知道从何学起,开始的时候非常迷茫,实在是每天回复很多人也很麻烦,所以在这里统一作个回复吧。 Java学习路线 当然,这里我只是说Java学习路线,因为自己就是学Java的,对Java理当很熟悉,对于其它方面,我也不是很了解。 基础阶段 首先是基础阶段,在基础阶段,我们必须掌握Java基础,Mysql数据库,Ora...
反转!物联网火爆,程序员开发技能却有待加强?
近几年来,物联网发展迅速:据中商产业研究院《2016——2021年中国物联网产业市场研究报告》显示,预计到2020年,中国物联网的整体规模将达2.2万亿元,产业规模比互联...
推荐一位好朋友 | 机械转大数据,并拿到66个offer
锦锋是我的好朋友,他自学编程从车辆工程转到了Java开发然后转大数据,在校招中拿了大小厂66个offer,其中有头条、腾讯等。除了学习之外,他还是国家高级健身教练,同时也...
让程序员崩溃的瞬间(非程序员勿入)
今天给大家带来点快乐,程序员才能看懂。 来源:https://zhuanlan.zhihu.com/p/47066521 1. 公司实习生找 Bug 2.在调试时,将断点设置在错误的位置 3.当我有一个很棒的调试想法时 4.偶然间看到自己多年前写的代码 5.当我第一次启动我的单元测试时 ...
接私活必备的 10 个开源项目!
点击蓝色“GitHubDaily”关注我加个“星标”,每天下午 18:35,带你逛 GitHub!作者 | SevDot来源 | http://1t.click/VE8W...
不要在网站上无限滚动!
人们在浏览网站的时候是喜欢用“无限滚动”,还是喜欢点击“阅读更多”或“查看更多”?无限滚动消除了分页的需要——分页是将数字内容分离到不同页面的过程。但这种方式真的好吗? 作者|Monish reddy 译者 |风车云马,责编 | 屠敏 出品 | CSDN(ID:CSDNnews) 以下为译文: 下面是我对无限滚动的看法,说明为什么它会导致不良后果。 对于某些用户来说,无限...
为什么你的努力可能是没用的?
看到这个标题,不少朋友可能直观的以为后面的内容不是励志的鸡汤就是广告。那就错了,这篇文章只是满满的干货。内容来自最近一段时间探索学习外加亲身感悟汇集而成。 前段时间和一位朋友聊天,聊到如何通过自由职业挣钱的事,朋友问:你准备怎样挣钱?我把自己看到的、听到的、经历的,外加想象的说了一遍。朋友问:这些你做到哪些了?顿时哑然。是啊,说了这么多,又做到了哪些呢?又将哪些做到了极致呢?如果没有做到极致,只努...
100 个网络基础知识普及,看完成半个网络高手
1)什么是链接? 链接是指两个设备之间的连接。它包括用于一个设备能够与另一个设备通信的电缆类型和协议。 2)OSI 参考模型的层次是什么? 有 7 个 OSI 层:物理层,数据链路层,网络层,传输层,会话层,表示层和应用层。 3)什么是骨干网? 骨干网络是集中的基础设施,旨在将不同的路由和数据分发到各种网络。它还处理带宽管理和各种通道。 4)什么是 LAN? LAN 是局域网的缩...
技术一旦被用来作恶,究竟会有多可怕?
技术一直都在被用来作恶。 作为与经常与黑客、攻击者打交道的我们,熟知各种用技术作恶的手段。 这篇就作为简单的科普文来跟大家讲一讲。 作恶之一:DDoS攻击 用简单的一句话介绍DDoS攻击就是:黑客在短时间里发起大量的恶意流量,导致被攻击的业务带宽塞满使得正常用户无法访问。 再通俗一点,你可把DDoS攻击看作一群挤入商店的恶意顾客,他们不买东西,只瞎嚷嚷,目的是让真正的顾客堵在门外没办法购物。最终的...
学Linux到底学什么
来源:公众号【编程珠玑】 作者:守望先生 网站:https://www.yanbinghu.com/2019/09/25/14472.html 前言 ​我们常常听到很多人说要学学Linux或者被人告知说应该学学Linux,那么学Linux到底要学什么? 为什么要学Linux 在回答学什么之前,我们先看看为什么要学。首先我们需要认识到的是,很多服务器使用的是Linux系统,而作为服务器应...
C语言这么厉害,它自身又是用什么语言写的?
这是来自我的星球的一个提问:“C语言本身用什么语言写的?”换个角度来问,其实是:C语言在运行之前,得编译才行,那C语言的编译器从哪里来? 用什么语言来写的?如果是用C语...
win10电脑工具整理 - 常用工具!
如题,本文主要为博主对电脑上安装的一些软件,所做的整理,当做备份用吧。 一、分类 系统工具 办公软件 编程开发 数据库相关 图片视频工具 网络及下载工具 解压缩工具 影音娱乐工具 二、软件工具 1.系统工具 1.1. 磁盘管理 PartAssist:一款好用的磁盘分区管理工具。 1.2. 修复、引导 EasyBCD:一款常用的系统引导和修复工具。 1.3. 虚拟机管理工具 win10...
第二弹!python爬虫批量下载高清大图
文章目录前言下载免费高清大图下载带水印的精选图代码与总结 前言 在上一篇写文章没高质量配图?python爬虫绕过限制一键搜索下载图虫创意图片!中,我们在未登录的情况下实现了图虫创意无水印高清小图的批量下载。虽然小图能够在一些移动端可能展示的还行,但是放到pc端展示图片太小效果真的是很一般!建议阅读本文查看上一篇文章,在具体实现不做太多介绍,只讲个分析思路。 当然,本文可能技术要求不是特别高,但可以...
面试官,不要再问我三次握手和四次挥手
三次握手和四次挥手是各个公司常见的考点,也具有一定的水平区分度,也被一些面试官作为热身题。很多小伙伴说这个问题刚开始回答的挺好,但是后面越回答越冒冷汗,最后就歇菜了。 见过比较典型的面试场景是这样的: 面试官:请介绍下三次握手 求职者:第一次握手就是客户端给服务器端发送一个报文,第二次就是服务器收到报文之后,会应答一个报文给客户端,第三次握手就是客户端收到报文后再给服务器发送一个报文,三次握手就...
相关热词 c# mysql插入 c# sha256 加密 c#窗体上的叉添加事件 c#打印图片文件 c#後台調前台js c#控制台美化 c# 标记 浮点型 c#获取当前的农历日期 c# 构造函数重载 c# 页面功能注释