在ADO.NET entity Framework中可通过VS工具可视操作生成,概念架构定义语言 (CSDL)、存储架构定义语言 (SSDL) 和映射规范语言 (MSL) 文件,但有时候也要手动的去操作一下,在网上找到一操作说明,点击这里可以查看原文 。其中主要的 model 和参数如下:

使用 EdmGen.exe 工具时,必须指定以下模式之一。

模式 说明

/mode:ValidateArtifacts

验证 .csdl、.ssdl 和 .msl 文件并显示所有错误或警告。

此选项需要至少一个 /inssdl/incsdl 参数。如果指定 /inmsl,则还需要 /inssdl/incsdl 参数。

/mode:FullGeneration

使用 /connectionstring 选项中指定的数据库连接信息,生成 .csdl、.ssdl、.msl、对象层和视图文件。

此选项需要一个 /connectionstring 参数,以及一个 /project 参数或 /outssdl/outcsdl/outmsl(注:不是outmsdl)、/outobjectlayer/outviews/namespace/entitycontainer 参数。

/mode:FromSSDLGeneration

根据指定的 .ssdl 文件生成 .csdl 和 .msl 文件、源代码和视图。

此选项需要 /inssdl 参数,以及 /project 参数或 /outcsdl/outmsl/outobjectlayer/outviews/namespace/entitycontainer 参数。

/mode:EntityClassGeneration

创建包含根据 .csdl 文件生成的类的源代码文件。

此选项需要 /incsdl 参数,以及 /project 参数或 /outobjectlayer 参数。/language 参数是可选的。

/mode:ViewGeneration

创建包含根据 .csdl、.ssdl 和 .msl 文件生成的视图的源代码文件。

此选项需要 /inssdl/incsdl/inmsl,以及 /project/outviews 参数。/language 参数是可选的。

 选项
选项 说明

/p[roject]:<字符串>

指定要使用的项目名称。项目名称用作命名空间设置、EDM 文件名、对象源文件名、视图生成源文件名的默认值。实体容器名称设置为 <项目>Context。

/prov[ider]:<字符串>

用于生成存储模型 (.ssdl) 文件的 .NET Framework 数据提供程序的名称。默认提供程序是用于 SQL Server 的 .NET Framework 数据提供程序 (System.Data.SqlClient)。

/c[onnectionstring]:<连接字符串>

指定用于连接数据源的字符串。

/incsdl:<文件>

指定 .csdl 文件或 .csdl 文件所在的目录。此参数可多次指定,这样可以指定多个目录或 .csdl 文件。当概念模型跨多个文件拆分时,对于生成类 (/mode:EntityClassGeneration) 或视图 (/mode:ViewGeneration),指定多个目录十分有用。如果希望验证多个模型 (/mode:ValidateArtifacts),这样做也很有用。

/refcsdl:<文件>

指定用于解析源 .csdl 文件中的任何引用的其他 .csdl 文件。(源 .csdl 文件是 /incsdl 选项指定的文件)。/refcsdl 文件包含源 .csdl 文件所依赖的类型。此参数可多次指定。

/inmsl:<文件>

指定 .msl 文件或 .msl 文件所在的目录。此参数可多次指定,这样可以指定多个目录或 .msl 文件。当概念模型跨多个文件拆分时,对于生成视图 (/mode:ViewGeneration),指定多个目录十分有用。如果希望验证多个模型 (/mode:ValidateArtifacts),这样做也很有用。

/inssdl:<文件>

指定 .ssdl 文件或 .ssdl 文件所在的目录。

/outcsdl:<文件>

指定将创建的 .csdl 文件的名称。

/outmsl:<文件>

指定将创建的 .msl 文件的名称。

/outssdl:<文件>

指定将创建的 .ssdl 文件的名称。

/outobjectlayer:<文件>

指定包含根据 .csdl 文件生成的对象的源代码文件的名称。

/outviews:<文件>

指定包含所生成的视图的源代码文件的名称。

/language:[VB|CSharp]

指定生成的源代码文件的语言。默认语言为 C#。

/namespace:<字符串>

指定要使用的命名空间。命名空间是在运行 /mode:FullGeneration/mode:FromSSDLGeneration 时在 .csdl 文件中设置的。在运行 /mode:EntityClassGeneration 时不使用该命名空间。

/entitycontainer:<字符串>

指定在生成的 EDM 文件中应用于 <EntityContainer> 元素的名称。

/help?

显示工具的命令语法和选项。

/nologo

禁止显示版权信息。

       

       如果你想从SQLSERVER 数据库中生成.ssdl,cdsl,msl 文件 可使用如下命令:>EdmGen /mode:FullGeneration   /connectionstring:"server=localhost;user id=admin;password=123456;persist security info=True;database=testDB" /provider:"System.Data.SqlClient" /outssdl:test.ssdl /outcsdl:test.csdl  /outmsl:test.msl /outobjectlayer:testobj.cs /outviews:testview.cs  /namespace:"TestSpace"   /entitycontainer:"Testentitycontainer"或者

去掉 “/provider:"System.Data.SqlClient” 也可以,因为用于生成存储模型 (.ssdl) 文件的 .NET Framework 数据提供程序的名称默认提供程序是用于 SQL Server 的 .NET Framework 数据提供程序 (System.Data.SqlClient)。

 

    如果你想从MYSQL(测试的mysql是5.0.3版本的) 数据库中生成 .ssdl,cdsl,msl 文件 可使用如下命令:>EdmGen /mode:FullGeneration   /connectionstring:"server=localhost;user id=admin;password=123456;persist security info=True;database=testDB" /provider:"MySql.Data.MySqlClient"
/outssdl:test.ssdl /outcsdl:test.csdl  /outmsl:test.msl /outobjectlayer:testobj.cs /outviews:testview.cs  /namespace:"TestSpace"   /entitycontainer:"Testentitycontainer"
   即可。不过一定要拷文件 MySql.Data.dll,  MySql.Data.Entity.dll, EdmGen.exe.config 和 EdmGen.exe 放在同一文件夹下面。其中EdmGen.exe.config 文件内容为:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  
<runtime>
    
<generatePublisherEvidence enabled="false"/>
  
</runtime>
<system.data>
    
<DbProviderFactories>
      
<add name="MySQL Data Provider" invariant="MySql.Data.MySqlClient" description=".Net Framework Data Provider for MySQL" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.0.3.0, Culture=neutral, PublicKeyToken=92c3c527cdfe7566" />
    
</DbProviderFactories>
  
</system.data>
</configuration>

执行命之后你发现在指定目录下面生成了:test.csdl,test.ssdl ,test.msl, testobj.cs, testview.cs 五个文件,此段工作完成。

 

posted on 2010-11-10 17:25  micenter  阅读(1930)  评论(0编辑  收藏  举报