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

相关文章

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg