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

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

列表显示只是一个表象,二者没有设定好的关联。实际的删除 *** 作应该在数据库中进行,也就是执行删除工作后,你得把列表数据刷新一下,重新显示。

具体的函数实现,如果需要我再贴上来。

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

{

int i = 0;

if(!m_pSet->IsOpen())

AfxMessageBox("数据源未打开");

m_ItemSetExtendedStyle(m_ItemGetExtendedStyle()|LVS_EX_FULLROWSELECT);

m_ItemDeleteAllItems();

m_ItemSetRedraw(FALSE);

if (!m_pSet->GetRecordCount() == 0)

{

m_pSet->MoveFirst();

}

while(!m_pSet->IsEOF())

{

m_ItemInsertItem(i,"");

m_ItemSetItemText(i,0,m_pSet->m_column1);

m_ItemSetItemText(i,1,m_pSet->m_column2);

m_ItemSetItemText(i,2,m_pSet->m_column3);

m_ItemSetItemText(i,3,m_pSet->m_column4);

i+=1;

m_pSet->MoveNext();

}

m_ItemSetRedraw(TRUE);

}

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

{

// TODO: Add your control notification handler code here

int listIndex; //当前选中项的索引

//首先得到点击的位置

POSITION pos=m_ItemGetFirstSelectedItemPosition(); //0 based m_item是指代列表控件

if(pos==NULL)

return;

//得索引,通过POSITION转化

listIndex=m_ItemGetNextSelectedItem(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_mCTTSetAddNew();

CString str1,str2,str3,str4;

str1Format("%s",m_Index);

str2Format("%f",m_UseHs);

str3Format("%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_mCTTSetm_column1 = str1; //Index

m_mCTTSetm_column2 = str2; //the use of hansi

m_mCTTSetm_column3 = str3; //the use of hanji

m_mCTTSetm_column4 = str4; //the style of hanjie

m_mCTTSetUpdate();

m_mCTTSetRequery();

MessageBeep(MB_OK);

CMainFrame pframe = (CMainFrame)AfxGetMainWnd();

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

pInterfaceView->ListItem();

return 0;

}

CString Filepath="Dataaccdb";

int i=m_listGetItemCount();//在列表的队尾添加,所以先获取行数

dbOpen(Filepath);

DbsetOpen(AFX_DAO_USE_DEFAULT_TYPE,"SELECT FROM DataTable",0);

DbsetAddNew();//在记录集的队尾添加

DbsetSetFieldValue("Name",_variant_t(m_name));

DbsetSetFieldValue("Age",atol(m_age));//将CString格式转换为数据库规定的格式

DbsetSetFieldValue("Extra",_variant_t(m_extra));

DbsetUpdate();//一定要及时更新

DbsetClose();

dbClose();//并关闭////////////////////////////

看这段代码,是把三个edit控件里的值写入Dataaccdb数据库文件中。

你首先安装Mysql,然后使用下面代码

在MyProc类中增加MySqlConnect方法,strUSR,strPWD分别为用户名和密码,登陆数据库需要

BOOL MyPorc::MySqlConnect(CString strUSR,CString strPWD)

{

unsigned short Port = 3306; //端口

CString IPAddress ="127001"; //本地数据库

CString UserName = strUSR;

CString Password = strPWD;

ssock=(MYSQL )malloc(sizeof(MYSQL));

mysql_init(ssock);

if(ssock == NULL)

{

AfxMessageBox("连接失败,请稍后在试! ");

return FALSE;

}

ssock = mysql_real_connect(ssock, IPAddress, UserName, Password, NULL, Port, NULL, 0);

if(!ssock)

{

unsigned int mtint = mysql_errno(ssock);

AfxMessageBox("登陆失败! ");

return FALSE;

}

return TRUE;

}

给你个实例 只是一部分 应该有你要的全部东西了 至于变量与控件关联,用一下VC60的winzard就 会明白了 快捷键 ctrl+w

//////////////cpp部分

BOOL Subjectdlg::OnInitDialog()

{

CDialog::OnInitDialog();

// TODO: Add extra initialization here

CString sqlStr;

sqlStr="SELECT FROM tb_subject";

mysubjectset = new Subjectinfo(&((CStudentsysApp)AfxGetApp())->m_DB);

if(!mysubjectset->Open(AFX_DB_USE_DEFAULT_TYPE,sqlStr)) //打开数据表

{

AfxMessageBox("tb_subject表打开失败!");

}

return TRUE; // return TRUE unless you set the focus to a control

// EXCEPTION: OCX Property Pages should return FALSE

}

bool Subjectdlg::DisplayRecord()

{

if(mysubjectset->IsEOF()&&mysubjectset->IsBOF()) //判断是否移动到了开头和结尾

{

m_subjectname = "";

m_subjectid = "";

}

else

{

if(mysubjectset->IsBOF()) //移动到了开头,就向后移动

{

mysubjectset->MoveNext();

}

else //否则前移

{

if(mysubjectset->IsEOF())

{

mysubjectset->MovePrev();

}

}

}

m_subjectname = mysubjectset->m_subject; //对应变量赋值

m_subjectid = mysubjectset->m_code;

UpdateData(FALSE);

return TRUE;

}

////////////那几个指针

Subjectinfo mysubjectset;

Subjectinfo mysubjectset_find;

Subjectinfo myclass_subject_findref;

///////////

subjectinfo是连接数据源的那个类

可以userinfor中创建一个列int level;

level是1为管理员,为0是用户,得到值,再select from xx表再次查询也可以

在验证得知是管理时就不用, m_pConnection->Close();,等下次查询完再关闭连接

以上就是关于怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改全部的内容,包括:怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改、求教MFC对话框中如何将数据写入数据库中、MFC如何用数据库等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9696811.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存