CDaoRecordset::SetFieldDirty

调用此成员函数标记记录集的字段数据成员标记为已更改或作为原样。

void SetFieldDirty(
   void* pv,
   BOOL bDirty = TRUE 
);

参数

  • pv
    在记录集或 NULL包含字段数据成员的地址。如果 NULL,记录集的所有字段数据成员标记。(C++ NULL 与在数据库术语的Null,并不意味着“具有value ". ")

  • bDirty
    TRUE,如果字段数据成员将标记为“错误” (更改)。否则 FALSE,如果字段数据成员将标记“清理” (未更改)。

备注

标记字段,当未更改的确保该字段不更新。

该结构指示已更改的字段数据成员以确保它们到该记录将写入该数据源。DAO记录字段交换(DFX)结构。更改的值自动字段通常会设置错误该字段,因此,您很少需要调用 SetFieldDirty,但是,有时您可能想确保列将被显式更新或插入无论值在字段数据成员。DFX framework还使用 PSEUDONULL。有关更多信息,请参见 CDaoFieldExchange::m_nOperation

如果不使用双缓冲结构,则将该字段的值不会自动设置字段为"。在这种情况下,显式设置字段为"是必需的。在 m_bCheckCacheForDirtyFields 包含的标志来控制此字段自动检查。

说明说明

在调用 编辑AddNew后,调用此成员函数。

使用函数的第一个参数的 NULL 将函数应用于所有 outputColumn 字段,在 CDaoFieldExchange的不是 param 字段。例如,调用

SetFieldDirty(NULL);

将设置仅 outputColumn 字段设置为 NULL; param 字段将不受影响。

param若要工作,必须提供单个要使用的 param 物理地址,例如:

SetFieldDirty(&m_strParam);

这意味着不能将所有 param 字段添加到 NULL,在中,您可以使用 outputColumn 字段。

SetFieldDirty 通过 DoFieldExchange实现。

要求

Header: afxdao.h

请参见

参考

CDaoRecordset选件类

层次结构图

CDaoRecordset::SetFieldNull

CDaoRecordset::SetFieldValue