A. MFC 如何将数据库某表的字段值(如字符串)直接显示到下拉框中
你说的下拉框是combox控件吧,这个控件有个AddString()的方法,用这个方法添加,当然了你先要用ADO,或者ODBC的方法从数据库读出来,如果多条记录,你都读出来之后,就要遍历添加了
B. 用mfc编写程序 access数据库新表建立失败
先建立一个和Data.mdb数据库的连接(connection),然后才能执行sql语句建立表。
C. 在VC的MFC中,视图中如何显示ACCESS数据库中表的字段,主要是OLE字段
用ado,很简单。介绍很多,就不贴过来了。
数据表直接用access建,也可以用sql语句建。
我用这个链接数据库在别的电脑上还没遇到过问题
D. MFC下如何查看access数据库中有多少个表
1,打开该access数据库,数据库工具,点击关系。2,然后便会出现各个表之间对应的关系。点击它们之间的连线,右击,便可以看到它们的关系了
E. 怎样将数据库中数据表显示在MFC操作界面上
1. 将MFC对话框中的控件与变量绑定;
2. 使用数据库接口(例如OLEDB)读出所需的数据;
3. 将数据填入变量中。
F. MFC ODBC访问数据库多张表
odbc连接A这个数据库就只需要一个CRecordset,即他的数据源就是A这个数据库。
多张表的意思是在A这个数据库中建立多张表,查询多张表就得靠sql语句来实现。
比如A数据库中有user和food两张表,查询两个表就得类似的写select * from user,这是查询user的所有内容。from就是查询哪张表。
G. MFC 使用数据库表的问题
你使用MFC来建立数据源,MFC建立出来的数据集会以表为单位建立类,数据集包含了表中的每个字段, 对于多表你就多建立几个数据集就可以了,做到一一对应
H. MFC如何获得数据库中表的个数
你首先要创建一个连接数据库的对象,比如你用cdatabase连接数据库后,然后用crecordset对象去打开表,那你运行crecordset对象的open函数,其中select语句用下面的格式:
select count(sysobjects.name ) from sysobjects.xtype ='U';
在数据库的sysobjects表里有这个数据库全部表的信息, xtype值为'U'的就是表名;
然后调用movefirst;
然后调用crecordset的getfieldvalue函数既可以获取值;
I. 怎样将数据库中数据表显示在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;
}