如何基于DbContext以编程方式生成实体框架模型DbFirst



我正在寻找一种基于DbContext为给定数据库以编程方式生成实体框架模型Database First的方法。

现在,我一直在尝试类System.Data.Entity.Design.EntityCodeGenerator,但似乎只是基于ObjectContext生成它们。

http://msdn.microsoft.com/en-us/library/system.data.entity.design.entitycodegenerator(v=vs.110).aspx

在这里我找到了关于如何使用它的信息:http://blogs.msdn.com/b/adonet/archive/2008/06/20/edm-tools-options-part-1-of-4.aspx

但仍然只生成基于ObjectContext的模型。

更新:我需要在VisualStudio扩展内部执行此操作(因此它将VisualStudio作为沙盒)。

好的,我找到了一种方法,在这里记录它,以防其他人遇到同样的问题:我没有用System.Data.Entity.Design.EntityCodeGenerator为模型后端(例如model.Designer.cs)生成代码,现在我只是将.edmx添加到Visual Studio项目中,设置一些属性,Visual Studio负责所有事情:

private void AddToProject( string edmxPath)
{
string edmxCodePath;
ProjectItem pi = _vsProj.Project.ProjectItems.AddFromFile(edmxPath);
// this little magic replaces having to use System.Data.Entity.Design.EntityCodeGenerator
pi.Properties.Item("ItemType").Value = "EntityDeploy";
pi.Properties.Item("CustomTool").Value = "EntityModelCodeGenerator";
if( efVersion == BaseWizard<BaseWizardForm, BaseCodeGeneratorStrategy>.ENTITY_FRAMEWORK_VERSION_6)
{
// For EF6 we use DbContext instead of ObjectContext based context.
_vsProj.DTE.SuppressUI = true;
EnvDTE80.Solution2 sol = (EnvDTE80.Solution2)_vsProj.DTE.Solution;
string itemPath = "";
if( this.Language == LanguageGenerator.CSharp )
{
itemPath = sol.GetProjectItemTemplate("DbCtxCSEF6", "CSharp" );
} else {
itemPath = sol.GetProjectItemTemplate("DbCtxVBEF6", "VisualBasic");
}
pi.ProjectItems.AddFromTemplate(itemPath, this._modelName);
// update $edmxInputFile$
string path = Path.GetDirectoryName(edmxPath);
string templateName = Path.Combine(path, _modelName + ".tt");
string contents = File.ReadAllText(templateName);
File.WriteAllText(templateName, contents.Replace("$edmxInputFile$", _modelName + ".edmx"));
templateName = Path.Combine(path, _modelName + ".Context.tt");
contents = File.ReadAllText(templateName);
File.WriteAllText(templateName, contents.Replace("$edmxInputFile$", _modelName + ".edmx"));
}
}

说明:该方法接收生成的.edmx文件的路径,如果EF版本为6,则模板";DbCtxSEF6";被实例化(它总是与VS2013一起安装),然后只需将$edmxInputFile$替换为edmx文件名;Visual Studio将自动添加.tt模板并生成后端代码。

有关上下文中的更多详细信息,请参阅MySql For Visual Studio 1.2.1或更高版本中MySql.Data.VisualStudio.Wizards.EntityFrameworkGenerator类的代码。

安装程序和源代码(其开源)可在以下网址获得:

http://dev.mysql.com/downloads/windows/visualstudio/

最新更新