如何根据数据库表中数据,使用控件在浏览器画出关系图

如何根据数据库表中数据,使用控件在浏览器画出关系图,第1张

用一个DetailsView控件

该控件非常适合你的需求

使用方法 首先配置数据源 不多说了 当进入这个页面时候你需要获取显示该用户全部数据的数据源 绑定到DetailsView控件上

然后设置DetailsView控件AutoGenerateEditButton为True

这时候你就发现控件下方出现了一个编辑按钮

然后你可以编辑模板 在editItem模板中拖入一个TEXTBOX 并设置绑定数据

也就是你所说的双向绑定

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

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

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;

}

使用UpdateRecord方法可以将绑定的数据感知控件的当前内容写入到数据库中,用这种方法在Validate事件中将被绑定的控件的内容保存到数据库中而不会再次触发Validate事件。

2UpdateControls方法

使用updateControls方法可以将数据从数据库中重新读到约束控件中,恢复为原始值,等效于用户更改了数据之后取消更改。

3Refresh方法

Refresh方法用来重新建立或显示与Data控件相连的数据库记录集。如果在程序代码中改变了:DatabaseName、ReadOnly、Exclusive或Connect的属性值,就必须用Refresh方法来刷新记录集。

Refresh方法的语法为:

以下是引用片段:

Data1refresh

另外Data控件的方法还有Drag、Move、Zorder、ShowWhatsThis方法,它们在数据控件上的用法与其他对象的用法是一致的。

下面通过一个小例子来熟悉Data控件的使用,按以下步骤制作一个使用Data控件 *** 作数据库的程序,使用的数据库是前章中制作的学生学籍管理的Access数据库。具体步骤如下。

·在Visual Basic中新建一个工程,命名为useData,保存于适当的目录下。

·打开程序的主窗体,设置其Caption为“Data控件的使用实例”。

·向窗体中添加Data控件,默认name为Datal。

·为数据显示的方便,向窗体中添加DBGird控件,用于显示查询出的数据。这个控件在后面还会有详细的讲解,这里只是使用一下。选择“工程/ 部件”命令,在d出的对话框中选择“Microsoft Data Bound ConU0l”复选框,然后点击确定按钮,DBGird控件就会加到工具箱中。

·设置DBGird的Caption为数据显示表格,并设置其DataSource属性为’Datal,用于显示Datal的数据,以便我们看清数据库的变化。

·根据我们学过的来设置Data控件的属性。首先连接使用的数据库,单击Data控件,在Properties窗口中找到connet属性,因为数据库是用Access制作的,故设置其连接的数据库类型为Access类型

·找到DataBase属性,这一项是设置Data控件指向的数据库,设置其路径,在此为DADatabase学生学籍管理mdb。

·然后设置Data控件的RecordSource属性,首先设定其为学生学籍管理mdb中的学生学籍表。运行程序,可以看到整个学生学籍表的数据全部显示到了DBGir-d中。

·因为Recordsource中既可以指定某一表,也可以使用SQL语句。

FETCH emp_user INTO :ls_FieldName,:ls_UserName;loopCLOSE emp_user;那么,你在数据库中应该有一张维护表二个字段(分别是数据窗口中的静态文本控件名称,对应的需要显示的名称:举例数据:(表中第二列允许用户修改)FieldName UserNamest_name

以上就是关于如何根据数据库表中数据,使用控件在浏览器画出关系图全部的内容,包括:如何根据数据库表中数据,使用控件在浏览器画出关系图、怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改、数据查询链接控件有哪些等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存