.NET Framework 4.0不能用sqlite的问题解决方法
这是因为.NET Framework 4.0中把版本号全部统一成4.0了,而这个SQLite provider是.NET 2.0的。 解决方法是在app.config的configuration节点下加入以下节点: <startupuseLegacyV2RuntimeActivationPolicy="true"> <supportedRuntimeversion="v4.0"sku=".NETFramework,Version=v4.0"/></startup> 我的原来是这样的 <startup> <supportedRuntimeversion="v4.0"sku=".NETFramework,Version=v4.0"/></startup> 以下是网上找的资料,比较详细的分析(http://www.poluoluo.com/jzxy/201305/207264.html) 查阅了相关资料,stackoverflow.com上建议在config文件中增加配置: <startup useLegacyV2RuntimeActivationPolicy="true"> MSDN上也对此方法进行了阐述,参见http://msdn.microsoft.com/en-us/library/bbx34a2h(VS.100).aspx 但是使用此方法编译后问题仍然没有解决,但是问题可以明确锁定为.net runtime环境的问题了。 <requiredRuntime version="v4.0.30319" /> 再次运行,问题解决。这下需要了解是什么原因造成的? 再次查阅CLR Runtime版本的相关资料,引用以下CLR运行规则和各版本间关系汇总表格,如下: 至此我们就能很清楚的搞清各个CLR版本之间的联系了。 总结:微软每次版本升级都会造成一些新的问题的出现,早年从CLRv1.0到CLRv2.0曾经也造成很多的困惑,可能也是由于过大的组织造成不能面面俱到吧,希望在今后的版本升级中能真正做到无缝的版本联接。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |