SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();
SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
在VS2010中编译上述代码,提示“无法嵌入互操作类型“SQLDMO.BackupClass”。请改用适用的接口。” 经过查阅相关资料发现,将引用的Interop.ADOX和Interop.SQLDMO引用属性中的嵌入互操作类型设置为False即可。
具体原理还不是特别理解,见http://www.cnblogs.com/pnljs/archive/2012/02/20/2359313.html
这里面提到一点,“嵌入互操作类型”设定为true,实际上就是不引入互操作集(编译时候放弃Com程序集),仅编译用户代码的程序集。而设定为false的话,实际就是需要从互操作程序集中获取 COM 类型的类型信息。这是不是意味着,嵌入是更轻量化的引用,只编译需要编译的部分,将引用的部分代码编译到本地的程序集中。而可以不依赖于原始的dll,比如Interop.ADOX。程序可以脱离该dll运行,因为所需要的代码已经“嵌入”到程序里了。
如此看来,这样确实可以减轻程序的负担,然而一旦遇到像这种,无法嵌入的话,只能老老实实引用这个dll,将“嵌入互操作类型”设置为False,即可。