怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改相关的知识,希望对你有一定的参考价值。

怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改查询的操作

列表显示只是一个表象,二者没有设定好的关联。实际的删除操作应该在数据库中进行,也就是执行删除工作后,你得把列表数据刷新一下,重新显示。
具体的函数实现,如果需要我再贴上来。

void CMCTTView::ListItem()//刷新列表

int i = 0;
if(!m_pSet->IsOpen())
AfxMessageBox("数据源未打开");
m_Item.SetExtendedStyle(m_Item.GetExtendedStyle()|LVS_EX_FULLROWSELECT);
m_Item.DeleteAllItems();
m_Item.SetRedraw(FALSE);
if (!m_pSet->GetRecordCount() == 0)

m_pSet->MoveFirst();


while(!m_pSet->IsEOF())


m_Item.InsertItem(i,"");

m_Item.SetItemText(i,0,m_pSet->m_column1);
m_Item.SetItemText(i,1,m_pSet->m_column2);
m_Item.SetItemText(i,2,m_pSet->m_column3);
m_Item.SetItemText(i,3,m_pSet->m_column4);

i+=1;
m_pSet->MoveNext();

m_Item.SetRedraw(TRUE);



void CMCTTView::OnItemDel() //在view类中删除条目

// TODO: Add your control notification handler code here
int listIndex; //当前选中项的索引
//首先得到点击的位置
POSITION pos=m_Item.GetFirstSelectedItemPosition(); //0 based m_item是指代列表控件
if(pos==NULL)
return;
//得索引,通过POSITION转化
listIndex=m_Item.GetNextSelectedItem(pos)+1; //1 based,so 1 added
m_pSet->SetAbsolutePosition(listIndex);

if ( MessageBox( _T( "你确定要删除当前单词信息吗?" ),
_T( "删除确认?" ), MB_OKCANCEL | MB_ICONQUESTION ) == IDOK )

m_pSet->Delete();
MessageBox( _T( "该单词信息已经被成功删除!" ),
_T( "删除成功!" ), MB_OK | MB_ICONASTERISK );
OnNext();

m_pSet->Requery();
//if(!m_pSet->GetRecordCount() == 0)
ListItem();


void CMCTTView::OnNext()

m_pSet->MoveNext();

if ( m_pSet->IsEOF() )
m_pSet->MoveFirst();


int CMCTTDoc::AddToAcc()//在doc类中添加数据

m_mCTTSet.AddNew();
CString str1,str2,str3,str4;
str1.Format("%s",m_Index);
str2.Format("%f",m_UseHs);
str3.Format("%f",m_UseHj);

switch (m_HJStyle)

case 0:
str4 = CString("类型1");
break;
case 1:
str4 = CString("类型2");
break;
case 2:
str4 = CString("类型3");
break;

m_mCTTSet.m_column1 = str1; //Index
m_mCTTSet.m_column2 = str2; //the use of hansi
m_mCTTSet.m_column3 = str3; //the use of hanji
m_mCTTSet.m_column4 = str4; //the style of hanjie

m_mCTTSet.Update();
m_mCTTSet.Requery();
MessageBeep(MB_OK);

CMainFrame* pframe = (CMainFrame*)AfxGetMainWnd();

CMCTTView* pInterfaceView = (CMCTTView*)pframe->GetActiveView();
pInterfaceView->ListItem();

return 0;
参考技术A 左转C++吧0.0

列表控件中的 MFC 对话框组合框

【中文标题】列表控件中的 MFC 对话框组合框【英文标题】:MFC Dialog Combo Box in a List Control 【发布时间】:2013-05-02 15:36:22 【问题描述】:

我正在尝试创建一个带有显示一列文本的列表控件(报告视图)的对话框窗口。我正在尝试添加另一个显示组合框的列,该组合框将包含第一列的可能操作列表。在 MFC 中是否有任何简单的方法可以做到这一点?

【问题讨论】:

【参考方案1】:

你不能用 CListCtrl 之类的东西来做到这一点(或者没有很多所有者绘制的代码)。相反,请查看像 CGridListCtrlEx 这样的第 3 方控件,它将为您完成所有繁重的工作。

【讨论】:

以上是关于怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改的主要内容,如果未能解决你的问题,请参考以下文章

怎样在MFC中的列表视图控件CListCtrl显示信息?谢谢

MFC中怎样实现组合框显示下拉列表啊?

限制列表控件 MFC 中的条目数

MFC中怎样将radio控件显示出来呢

列表控件中的 MFC 对话框组合框

MFC 读取http文件服务器上的文件列表,并选择文件进行下载