我希望通过将DbCompiledModel缓存到磁盘来减少EF6中的启动时间。
为DbContext编写EDMX文件很容易:
EdmxWriter.WriteEdmx(myDbContext, XmlWriter.Create(@"C:\temp\blah.xml"))
将DbCompiledModel传递给DbContext很容易:
var db = new DbContext(connectionString, myDbCompiledModel)
然而,似乎没有任何方法可以将EDMX文件从磁盘读入DbCompiledModel!我怎么能这样做?
请注意,我已在此分支版本的EF6中使用EdmxReader工具成功实施了解决方案:
https://github.com/davidroth/entityframework/tree/DbModelStore
但是我不愿在生产环境中使用分支版本。我尝试从这个分支中提取EdmxReader实用程序,但它依赖于DbCompiledModel的内部构造函数,我无法访问它。
那么,如何从磁盘获取EDMX文件并将其转换为DbCompiledModel?
答案 0 :(得分:1)
我测试了是否可以通过序列化DbCompiledModel来使其工作。
从EF获取它并在构建新上下文时提供它。问题是一切都是私有的,所以它不会序列化任何东西。
如果您可以获得用于序列化私有成员的序列化程序,那么它应该非常简单。
1)在OnModelCreating结束时(如果你先使用代码)你可以做到
modelBuilder.Build().Compile()
稍微简化,因为你应该提供一些参数
2)序列化那一个。对于私人成员的工作,请尝试查看JSON.Net: Force serialization of all private fields and all fields in sub-classes或尝试使用BinaryFormatter Why is the BinaryFormatter serializing private members and not the XMLSerializer or the SoapFormatter ?
3)将其保存到磁盘
4)从磁盘读取文件并将其反序列化为新的DbCompiledModel