随笔 - 41,  文章 - 4,  评论 - 342,  阅读 - 10万

  在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   micenter  阅读(2056)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端

< 2010年11月 >
31 1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 1 2 3 4
5 6 7 8 9 10 11
点击右上角即可分享
微信分享提示