------解决方案-------------------------------------------------------- 只能先判断是否为NULL然后面赋值
或者是数据库里表每个字段的值默认为空格" ",这样就不用判断了,这是在设计数据库里的表时定义的,每个字段都有各种属性,比如类型,大小,默认值,键值等属性
------解决方案--------------------------------------------------------也可以对查询语句进行处理,对于可能null的字段,改写为ISNULL(xxxx,'')强制返回一个值
------解决方案--------------------------------------------------------"SELECT ISNULL(字串字段名,''),ISNULL(整数字段名,0) FROM 表 "
ISNULL 是SQL Server中的函数,在你构造的查询语句中,由SQL服务器进行解析,确保不会返回不好处理的空值
------解决方案--------------------------------------------------------C/C++ code _variant_t var=m_AdoConnm_pRecordset->GetCollect("UserNo"); if(varvt != VT_NULL) m_GridSetItemText(i,0,(LPCTSTR)(_bstr_t)var); else m_GridSetItemText(i,0,TEXT(""));
判断他是不是NULL。是插入字符""不是就插入原值
列表显示只是一个表象,二者没有设定好的关联。实际的删除 *** 作应该在数据库中进行,也就是执行删除工作后,你得把列表数据刷新一下,重新显示。
具体的函数实现,如果需要我再贴上来。
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;
}
可以userinfor中创建一个列int level;
level是1为管理员,为0是用户,得到值,再select from xx表再次查询也可以
在验证得知是管理时就不用, m_pConnection->Close();,等下次查询完再关闭连接
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数据库文件中。
你没有添加数据源,在ODBC里添加数据源。
要选择相应的驱动程序。我举个例子,你的管理系统的数据库文件是mdb 日志文件是 LOG 采用的数据库是SQL2000 ODBC数据源连接。
配置方法:
1启动数据库SQL 2000 启动服务,将数据库文件添加到数据库中(附加数据库就行)
2打开ODBC数据源 在用户DSN标签下 添加->选择SQL Server驱动->完成->填上数据库的名称()和数据库(Local)->下一步->下一步->更改默认数据库(选择成你要添加的那个)->直接点OK就行了。
以上就是关于求问MFC 循环读取数据库中的表,表中字段有NULL时出现异常,如何修改全部的内容,包括:求问MFC 循环读取数据库中的表,表中字段有NULL时出现异常,如何修改、怎样将数据库中数据表显示在MFC中的列表控件上,并对其进行删除,修改、MFC 中 ADO 方式连接access数据库 如何进行表的切换等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)