手动使用EDM 生成器 (EdmGen.exe) 工具生成 SSDL,CSDL,MSL 文件

在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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值