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++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.