【EF 3】浅谈ADO数据模型生成串(一):csdl,ssdl,msl分析

2024-08-25 22:08

本文主要是介绍【EF 3】浅谈ADO数据模型生成串(一):csdl,ssdl,msl分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

导读:这段经历,真的是难以忘怀。恨得我牙痒痒,就一个字符串拼接,前前后后尽然报了不下30个错。有的错很快就能调出来,有的错调一天、两天,是真的可以的。最终总结了一下,这些错很大一部分原因是对于EF生成串的不理解造成的。所以,现在将自己这段时间的理解写下来。

 

一、前提背景

在项目中,我们需要用到动态切库,整个项目的大概框架是:客户端,MVC;服务端,WCF+EF。众所周知,我们只需要将EF生成串里的数据库连接更改掉,就可以实现对新数据库的操作。基于这种战略上轻视敌人的心理,再加上师哥师姐的的谆谆教诲,还有技术组长的鼓励,我就此走上了一条不归路。剧情透露:就拼一条字符串,我真心是拼了好多天。

二、代码展示

 

<span style="font-family:KaiTi_GB2312;font-size:18px;"><span style="font-family:KaiTi_GB2312;font-size:18px;"> <connectionStrings><add name="TestCrateDatabaseEntities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=myname;initial catalog=mydatabase;persist security info=True;user id=sa;password=mypassword;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" /></connectionStrings></span></span>


当我们使用ADO.NET数据实体模型生成的时候,就会在app.config里面出现如上一个代码串。那么,这句话到底是什么意思呢?

 

三、csdl,ssdl,msl分析

3.1,对应的代码:

metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;

3.2,出现的背景:

想实现切库,所以测试的时候,用了新建的库生成EF实体模型,然后截取了这条串拼到原有库的生成模型中去,第一个错,就是找不到csdl,ssdl,msl。

3.3,基本概念介绍:

概念架构定义语言 (CSDL): 是一种基于 XML 的语言,它描述构成数据驱动应用程序的概念模型的实体、关系和函数。即其中定义的实体、主键、属性、关联等都是对应于.NET Framework中的类型。此概念模型可以由实体框架 或 ADO.NET Data Services 使用。 实体框架 使用以 CSDL 描述的元数据将在概念模型中定义的实体和关系映射到数据源。

存储架构定义语言 (SSDL) :是一种基于 XML 的语言,用于描述实体框架应用程序的存储模型。即表、列、关系、主键及索引等数据库中存在的概念。在实体框架应用程序中,存储模型元数据从 .ssdl 文件(用 SSDL 编写)加载到 System.Data.Metadata.Edm.StoreItemCollection 的实例中,并且可以使用 System.Data.Metadata.Edm.MetadataWorkspace 类中的方法进行访问。 实体框架使用存储模型元数据将针对概念模型的查询转换为特定于存储的命令。

映射规范语言 (MSL): 是一种基于 XML 的语言,它描述了实体框架 应用程序的概念模型与存储模型之间的映射。在实体框架 应用程序中,映射元数据是在生成时从 .msl 文件(以 MSL 编写)加载的。 实体框架 在运行时使用映射元数据将对概念模型的查询转换为存储特定的命令。

 

这三者合在一起就是EDM模式。EDM模式在项目中的表现形式就是扩展名为.edmx的文件。这个文件本质是一个xml文件,可以手工编辑此文件来自定义CSDL、MSL与SSDL这三部分。

 

对应的程序代码:在生成的程序代码中,有一个properties文件,下面有一个AssemblyInfo类,在这个类里面,配置了这三个文件的相关数据。

 

3.4,分析问题原因:

当我用我新库生成的连接串去替换掉之前的连接串时,虽然表面上看起来metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;都是一样的,但实际上这三个文件已经变了。每一次生成,就会有一个对应的AssemblyInfo类文件,里面也相应的配置了这三个文件的具体信息。即使我替换掉了连接串,但是这几个文件的路径指向是没有改变的,这个类中的配置信息也是没有改变的,当它去它指定的路径找东西,就会出现找不到的情况。

 

3.5,解决方案

方案1,更改连接串:metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;将*前面这一部分,不用*代替,使用具体的文件(旧库生成文件路径)名称。

方案2,更改AssemblyInfo类文件,将这个类文件中的配置更改为自己需要的信息。

方案3,只替换连接串的一部分:其实换库,是没必要将这整句话都替换掉的(虽然前面那部分换不换,看起来都一样),只需要替换掉数据库连接。

 

四、总结

这几个文件,根据目前自己的理解,其实是相当于之前学过的dll文件一样的意思,我们用EF的时候看,其实主要还是用的这三个文件,就像我们之前在U层调D层一样,其实是使用的D层的dll文件。

有时候表面看起来一样的东西,其实质不一定一样,之所以报这么多的错,还一直解决不了,想了想,其实是自己对这一块的工作原理,真的很不明白。根本不知道关键的代码在哪里,根本不知道每一句代码意味着什么。报错的时候,才知道自己错了。

 

这篇关于【EF 3】浅谈ADO数据模型生成串(一):csdl,ssdl,msl分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106782

相关文章

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

Java使用Spire.Barcode for Java实现条形码生成与识别

《Java使用Spire.BarcodeforJava实现条形码生成与识别》在现代商业和技术领域,条形码无处不在,本教程将引导您深入了解如何在您的Java项目中利用Spire.Barcodefor... 目录1. Spire.Barcode for Java 简介与环境配置2. 使用 Spire.Barco

C++ scoped_ptr 和 unique_ptr对比分析

《C++scoped_ptr和unique_ptr对比分析》本文介绍了C++中的`scoped_ptr`和`unique_ptr`,详细比较了它们的特性、使用场景以及现代C++推荐的使用`uni... 目录1. scoped_ptr基本特性主要特点2. unique_ptr基本用法3. 主要区别对比4. u

SpringBoot集成iText快速生成PDF教程

《SpringBoot集成iText快速生成PDF教程》本文介绍了如何在SpringBoot项目中集成iText9.4.0生成PDF文档,包括新特性的介绍、环境准备、Service层实现、Contro... 目录SpringBoot集成iText 9.4.0生成PDF一、iText 9新特性与架构变革二、环

Nginx内置变量应用场景分析

《Nginx内置变量应用场景分析》Nginx内置变量速查表,涵盖请求URI、客户端信息、服务器信息、文件路径、响应与性能等类别,这篇文章给大家介绍Nginx内置变量应用场景分析,感兴趣的朋友跟随小编一... 目录1. Nginx 内置变量速查表2. 核心变量详解与应用场景3. 实际应用举例4. 注意事项Ng

Java多种文件复制方式以及效率对比分析

《Java多种文件复制方式以及效率对比分析》本文总结了Java复制文件的多种方式,包括传统的字节流、字符流、NIO系列、第三方包中的FileUtils等,并提供了不同方式的效率比较,同时,还介绍了遍历... 目录1 背景2 概述3 遍历3.1listFiles()3.2list()3.3org.codeha

idea-java序列化serialversionUID自动生成方式

《idea-java序列化serialversionUID自动生成方式》Java的Serializable接口用于实现对象的序列化和反序列化,通过将对象转换为字节流来存储或传输,实现Serializa... 目录简介实现序列化serialVersionUID配置使用总结简介Java.io.Seripyth

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

C#自动化生成PowerPoint(PPT)演示文稿

《C#自动化生成PowerPoint(PPT)演示文稿》在当今快节奏的商业环境中,演示文稿是信息传递和沟通的关键工具,下面我们就深入探讨如何利用C#和Spire.Presentationfor.NET... 目录环境准备与Spire.Presentation安装核心操作:添加与编辑幻灯片元素添加幻灯片文本操

Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)

《Python实现Word文档自动化的操作大全(批量生成、模板填充与内容修改)》在职场中,Word文档是公认的好伙伴,但你有没有被它折磨过?批量生成合同、制作报告以及发放证书/通知等等,这些重复、低效... 目录重复性文档制作,手动填充模板,效率低下还易错1.python-docx入门:Word文档的“瑞士