数据宏位于“王牌”数据库引擎中,因此其工作方式与 SQL Server 中的存储过程非常相似。但是,如果您调用 + 使用 VBA 例程(这是合法的),那么您将引入 VBA 依赖项,并且该设置仅适用于 Access。因此,如果您通过 ODBC 或 FoxPro 甚至 .net 的任何其他方式打开表,Access 存储过程仍将运行,但 VBA 依赖项将不起作用并且需要 Access。因此,您可以自由安装数据库引擎(以前称为 JET,现在称为 ACE)。像我们过去多年所做的那样安装数据引擎不会安装 VBA,数据库引擎也不会使用或依赖 VBA。
所以数据宏和数据触发代码将从 C# 中运行。但是,调用 VBA 代码需要安装 Access(安装 VBA)。更重要的是,当您有此类触发器调用 VBA 代码时,您必须只更新 Access 中的数据。
因此,ACE 中可用的循环和存储过程甚至可以调用其他存储过程,只要它们仅用 DATA 宏语言编写即可。
因此,让此类表触发器调用 VBA 代码意味着除了安装数据库引擎之外,您还需要依赖 VBA。因此,虽然您可以调用 VBA 代码,但这种设置仅在使用 MS-Access 作为客户端程序时有效。
因此,如果要从 c# 或其他外部语言进行更新,则必须将 VBA 代码重写为数据宏代码。
您确实拥有“大多数”VBA 函数,但没有记录集(每个都使用)。
编辑:我还应该指出,由于在 c# 中使用 ACE 时不能调用 VBA,另一条路是让数据宏对 SQL Server 的链接表进行操作,但数据宏不能对链接(外部)表进行操作。因此,如果数据是从 Access 更新的,那么您的设置肯定可以工作。但是,使用 FoxPro、VB、vb.net、c# 等。在这些情况下,您不能让数据宏代码调用 VBA 或任何其他类型的外部代码 - 并且需要外部代码来更新 SQL服务器,因为数据宏仅在本地本机表上运行(SQL 触发器也非常相似)