QQ登录

只需一步,快速开始

265上位机VC MFC使用ODBC在列表视图中删除记录

[ 复制链接 ]

265上位机VC MFC使用ODBC在列表视图中删除记录

265上位机VC MFC使用ODBC在列表视图中删除记录
265上位机VC MFC使用ODBC在列表视图中删除记录
功能展示
在列表视图中显示数据记录后,有时想针对某一数据进行删除操作,我们当前例程就实现对指定记录的删除操作功能,效果如右图,双击想要删除的记录后,例程会提示用户是否确认删除,点击OK就删除被双击的记录;
要点提示
1.删除记录的一般方法为先调用CListCtrl类的GetSelectionMark()成员函数,此函数用来获取当前鼠标所处视图中记录的序号,如果鼠标所在位置没有记录条目 ,函数返回-1,由于视图反映了记录集,通过Crecordset的Move()函数使记录集滚动到想要删除的记录上,再使用Crecordset类的成员函数Delete()执行删除;
2.注意在删除记录前记得调用Crecordset 类的成员函数MoveFirst()一次,不然可能会误删;
实现功能
1.新建一数据源再新建基于单文档的应用程序,记得视窗派生于CListView;
2.再用类向导新建一基于Crecordset的类CODBCSet,记得类型选择dynaset ;
在文档中类中添加此类的头文件#include “ODBCSet.h”及变量public:CODBCSetm_Set;在视窗中添加此类的头文件#include “ODBCSet.h”及变量public:CODBCSet *m_pSet; CListCtrl* m_List;
3.在视窗的构造函数中初始变化量,及析构函数中关闭记录集
  1. CGkbc8View::CGkbc8View()
  2. {
  3.         m_pSet=NULL;
  4.         m_List=&GetListCtrl();//获取列表视图控件
  5.         m_dwDefaultStyle|=LVS_REPORT;//以报表的格式显示
  6. }
  7. CGkbc8View::~CGkbc8View()
  8. {
  9.         if(m_pSet->IsOpen())        
  10.         m_pSet->Close();
  11. }
复制代码
4.在文档类添加视窗头文件#include "gkbc8View.h"并在OnNewDocument()函数中初始化视窗类的变量m_pSet
  1. BOOL CGkbc8Doc::OnNewDocument()
  2. {
  3.         if (!CDocument::OnNewDocument())
  4.                 return FALSE;

  5.         POSITION pos;
  6.         pos=GetFirstViewPosition();
  7.         CGkbc8View* pView =(CGkbc8View*)GetNextView(pos);
  8.         pView->m_pSet = &m_Set;
  9.         return TRUE;
  10. }
复制代码
5.在视窗类的OnInitialUpdate()函数中实现数据表内容的全部显示
  1. void CGkbc8View::OnInitialUpdate()
  2. {
  3.         CListView::OnInitialUpdate();

  4.         m_pList->SetRedraw(true);
  5.         m_pList->DeleteAllItems();
  6.         if(m_pSet==NULL)
  7.         {
  8.                 AfxMessageBox("还没有对记录集进行初始化");
  9.                 return;
  10.         }
  11.         if(!m_pSet->IsOpen())
  12.         {
  13.                 m_pSet->Open();//打开记录集
  14.         }
  15.         int i=0,j=0;
  16.         CODBCFieldInfo DbFi;//存储记录集字段信息的结构体
  17.         LV_COLUMN m_Lc;//存储列信息的结构体
  18.         m_Lc.mask=LVCF_FMT|LVCF_WIDTH|LVCF_TEXT|LVCF_SUBITEM;//设置列属性
  19.         //读取记录集的字段信息
  20.         for(i=0;i<m_pSet->m_nFields;i++)
  21.         {
  22.                 m_pSet->GetODBCFieldInfo(i,DbFi);
  23.                 m_Lc.iSubItem=i;
  24.                 m_Lc.fmt=LVCFMT_CENTER;
  25.                 m_Lc.cx=DbFi.m_strName.GetLength()*10+16;
  26.                 m_Lc.pszText=DbFi.m_strName.GetBuffer(DbFi.m_strName.GetLength());
  27.                 GetListCtrl().InsertColumn(i,&m_Lc);
  28.         }
  29.         //根据记录集的数据信息添加行
  30.         LV_ITEM m_item;//条目结构体对象
  31.         CString string;//字符串临时变量
  32.         CDBVariant DbVariant;
  33.         i=0;
  34.         if(m_pSet->IsEOF())//记录集是否为空
  35.         {
  36.                 AfxMessageBox("记录集没有记录");
  37.                 return;
  38.         }
  39.         m_pSet->MoveFirst();//从第一个记录开始
复制代码
  1. while(m_pSet->IsEOF()==0)//是否到达最后一个记录
  2.         {
  3.                 m_item.mask=LVIF_TEXT;
  4.                 m_item.iItem=i;
  5.                 m_item.iSubItem=0;
  6.                 m_pSet->GetFieldValue((short)0,string);
  7.                 m_item.pszText=string.GetBuffer(string.GetLength());
  8.                 m_pList->InsertItem(&m_item);//插入条目
  9.                 //显示列数据
  10.                 for(j=1;j<m_pSet->m_nFields;j++)
  11.                 {
  12.                         m_pSet->GetFieldValue((short)j,string);
  13.                         m_pList->SetItemText(i,j,string.GetBuffer(string.GetLength()));
  14.                 }
  15.                 m_pSet->MoveNext();//下移记录
  16.                 i++;
  17.         }
  18. }
复制代码
6添加视窗类的鼠标双击函数,实现双击删除数据条目功能
  1. void CGkbc8View::OnLButtonDblClk(UINT nFlags, CPoint point)
  2. {

  3.         CListView::OnLButtonDblClk(nFlags, point);
  4.         
  5.         if(m_pSet==NULL)
  6.         {
  7.                 AfxMessageBox("还没有对记录集进行初始化");
  8.                 return;
  9.         }        
  10.         int nCurSel;//双击鼠标左键时,要显示的记录的序号
  11.     nCurSel=m_pList->GetSelectionMark();
  12.         m_pSet->MoveFirst();
  13.         if(nCurSel!=-1)
  14.                 m_pSet->Move(nCurSel);

  15.         if(IDOK==MessageBox("真删?","",MB_OKCANCEL|MB_ICONWARNING) )
  16.                 m_pSet->Delete();

  17.         m_pList->SetRedraw(true);
  18.         m_pList->DeleteAllItems();
复制代码
  1. if(!m_pSet->IsOpen())
  2.                 m_pSet->Open();//打开记录集
  3.         int i=0,j=0;
  4.         LV_ITEM m_item;//条目结构体对象
  5.         CString string;//字符串临时变量

  6.         CDBVariant DbVariant;
  7.         i=0;
  8.         if(m_pSet->IsEOF())//记录集是否为空
  9.         {
  10.                 AfxMessageBox("记录集没有记录");
  11.                 return;
  12.         }
  13.         m_pSet->MoveFirst();//从第一个记录开始
  14.         while(m_pSet->IsEOF()==0)//是否到达最后一个记录
  15.         {
  16.                 m_item.mask=LVIF_TEXT;
  17.                 m_item.iItem=i;
  18.                 m_item.iSubItem=0;
  19.                 m_pSet->GetFieldValue((short)0,string);
  20.                 m_item.pszText=string.GetBuffer(string.GetLength());
  21.                 m_pList->InsertItem(&m_item);//插入条目
  22.                 //显示列数据
  23.                 for(j=1;j<m_pSet->m_nFields;j++)
  24.                 {
  25.                         m_pSet->GetFieldValue((short)j,string);
  26.                         m_pList->SetItemText(i,j,string.GetBuffer(string.GetLength()));
  27.                 }
  28.                 m_pSet->MoveNext();//下移记录
  29.                 i++;
  30.         }
  31. }
复制代码
最后记录在stdafx.h头文件上包含数据库支持的头文件#include <afxdb.h>  
我们来演示功能实现的整个过程
请点击此处下载

请先注册会员后在进行下载

已注册会员,请先登录后下载

文件名称:265.上位机VC MFC使用ODBC在列表视图中删除记录.zip 
文件大小:45.45 KB  售价:10金币
下载权限: 不限 以上或 VIP会员   [购买捐助会员]   [充值积分]   有问题联系我

  

您的支持是我们创作的动力!  

  

您可花点闲钱积分自助任意充值

  

成为VIP会员 全站资源任意下载永久更新!


回复

使用道具 举报

快速回复 返回列表 客服中心 搜索