DVD出租系统【5】界面初始化进一步完善

2024-02-17 06:48

本文主要是介绍DVD出租系统【5】界面初始化进一步完善,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、本节目的,完成下图这两个地方功能:

2、添加变量,DVD名字变量。

3、在头文件中添加函数声明:

4、在CPP中添加函数(初始化Combox控件),将函数添加到MFC初始化函数:

void CDVDRentDlg::InitDVDNameComboBox()
{_RecordsetPtr pDvdNameRecordset;pDvdNameRecordset.CreateInstance(__uuidof(Recordset));CString strSQL;strSQL = _T("SELECT sDVDName FROM tbDVDInfo");try{HRESULT hr = pDvdNameRecordset->Open(_variant_t(strSQL), m_pConnection.GetInterfacePtr(), adOpenDynamic, adLockOptimistic, adCmdText);if (FAILED(hr)) {return;}}catch (_com_error *e) {MessageBox(e->ErrorMessage());return;}CString strValue;_variant_t var;int iCurrIdx = 0;m_comboDVD.InsertString(iCurrIdx++, _T(""));try{while (!pDvdNameRecordset->GetadoEof()){var = pDvdNameRecordset->GetCollect(_T("sDVDName"));if (var.vt != NULL) {strValue = (LPCTSTR)_bstr_t(var);m_comboDVD.InsertString(iCurrIdx++, strValue);pDvdNameRecordset->MoveNext();}}pDvdNameRecordset->Close();pDvdNameRecordset = NULL;}catch (_com_error *e) {MessageBox(e->ErrorMessage());return;}
}

 5、运行如图:

6、接下里插入查询按钮的时间响应,同样在头文件声明函数,然后在.cpp文件添加函数代码:

void CDVDRentDlg::OnBnClickedButtonQuery()
{// TODO: 在此添加控件通知处理程序代码UpdateData(TRUE);_RecordsetPtr pQueryRecordset;pQueryRecordset.CreateInstance(__uuidof(Recordset));CString strDataFrom, strDataTo, strDVDName;m_comboDVD.GetWindowText(strDVDName);CString strSQL;if ((!m_check_Date) && m_name.IsEmpty() && strDVDName.IsEmpty()) {strSQL = _T("SELECT * FROM tbRentInfo");}else {strSQL = _T("SELECT * FROM tbRentInfo where");}if (m_check_Date) {CTime timeFrom, timeTo;m_DateFrom.GetTime(timeFrom);m_DateTo.GetTime(timeTo);m_DateFrom.GetWindowText(strDataFrom);m_DateTo.GetWindowText(strDataTo);if (timeFrom.GetMonth() > timeTo.GetMonth()) {MessageBox(_T("日期设置错误."));return;}else if (timeFrom.GetMonth() == timeTo.GetMonth()) {if (timeFrom.GetDay() > timeTo.GetDay()) {MessageBox(_T("日期设置错误."));return;}}strSQL.AppendFormat(_T(" sDate>=\'%s\' and sDate<=\'%s\'"), strDataFrom, strDataTo);}if (!m_name.IsEmpty()) {if (m_check_Date) {strSQL.AppendFormat(_T(" and sName=\'%s\'"), m_name);}else {strSQL.AppendFormat(_T(" sName=\'%s\'"), m_name);}}if (!strDVDName.IsEmpty()) {if ((!m_check_Date) && m_name.IsEmpty()) {strSQL.AppendFormat(_T(" sDVDID=%s"), QueryDVDId(strDVDName));}else {strSQL.AppendFormat(_T(" and sDVDID=%s"), QueryDVDId(strDVDName));}}////上面构造好SQL查询语句之后,下面就开始查询啦try{HRESULT hr = pQueryRecordset->Open(_variant_t(strSQL), m_pConnection.GetInterfacePtr(), adOpenDynamic, adLockOptimistic, adCmdText);if (FAILED(hr)) {return;}}catch (_com_error* e){MessageBox(e->ErrorMessage());return;}//判断记录集是否为空if (pQueryRecordset->GetadoEof()) {MessageBox(_T("记录集为空。。。"));return;}else {_variant_t var;CString strValue;int curItem = 0;m_rentInfoList.DeleteAllItems();try {while (!pQueryRecordset->GetadoEof()) {var = pQueryRecordset->GetCollect((long)0);if (var.vt != NULL)strValue = (LPCTSTR)_bstr_t(var);m_rentInfoList.InsertItem(curItem, strValue);var = pQueryRecordset->GetCollect(_T("sName"));if (var.vt != NULL)strValue = (LPCTSTR)_bstr_t(var);m_rentInfoList.SetItemText(curItem, 1, strValue);var = pQueryRecordset->GetCollect(_T("sDVDID"));if (var.vt != NULL)strValue = (LPCTSTR)_bstr_t(var);m_rentInfoList.SetItemText(curItem, 2, QueryDVDName(strValue));var = pQueryRecordset->GetCollect(_T("sDate"));if (var.vt != NULL)strValue = (LPCTSTR)_bstr_t(var);m_rentInfoList.SetItemText(curItem, 3, strValue);pQueryRecordset->MoveNext();curItem++;}}catch (_com_error *e) {MessageBox(e->ErrorMessage());return;}}pQueryRecordset->Close();pQueryRecordset = NULL;
}CString CDVDRentDlg::QueryDVDId(CString& DVDName)
{HRESULT hr;_RecordsetPtr pRentRecordset;hr = pRentRecordset.CreateInstance(__uuidof(Recordset));if (FAILED(hr)) {MessageBox(_T("创建记录集对象失败."));return FALSE;}try{CString strSQL;CString strDVDName;strDVDName=_T("'"+DVDName);strDVDName = strDVDName + _T("'");strSQL = _T("select * from tbDVDInfo where sDVDName="+strDVDName);MessageBox(strSQL);hr = pRentRecordset->Open(_variant_t(strSQL), m_pConnection.GetInterfacePtr(), adOpenDynamic, adLockOptimistic, adCmdText);if (SUCCEEDED(hr)) {_variant_t var;CString strValue;var = pRentRecordset->GetCollect(_T("sDVDID"));if (var.vt != NULL) {strValue = (LPCTSTR)_bstr_t(var);MessageBox(strValue);return strValue;}}else {MessageBox(_T("打开结果记录集失败."));return FALSE;}}catch (_com_error &e) {MessageBox(e.ErrorMessage());return FALSE;}pRentRecordset->Close();pRentRecordset = NULL;
}

7、运行结果如下:

8、本节工程地址:

链接:https://pan.baidu.com/s/16i5MlvklTdhFZ0tbR4Lb9A 
提取码:zeei 
 

这篇关于DVD出租系统【5】界面初始化进一步完善的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/716985

相关文章

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设