【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="data source=myname;initial catalog=mydatabase;persist security info=True;user id=sa;password=mypassword;MultipleActiveResultSets=True;App=EntityFramework"" 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分析的更多相关文章
- 【EF 2】浅谈ADO数据模型生成串(二):数据库连接串分析
导读:上篇博客中介绍了ADO生成串的前一部分,本篇博客结合报错,接着介绍剩下的部分. 一.代码展示 <span style="font-family:KaiTi_GB2312;font ...
- 谁还没遇上过NoClassDefFoundError咋地——浅谈字节码生成与热部署
谁还没遇上过NoClassDefFoundError咋地--浅谈字节码生成与热部署 前言 在Java程序员的世界里,NoClassDefFoundError是一类相当令人厌恶的错误,因为这类错误通常非 ...
- Python测试开发-浅谈如何自动化生成测试脚本
Python测试开发-浅谈如何自动化生成测试脚本 原创: fin 测试开发社区 前天 阅读文本大概需要 6.66 分钟. 一 .接口列表展示,并选择 在右边,点击选择要关联的接口,区分是否要登录, ...
- 浅谈时钟的生成(js手写代码)
在生成时钟的过程中自己想到布置表盘的写法由这么几种: 当然利用那种模式都可以实现,所以我们要用一个最好理解,代码有相对简便的方法实现 1.利用三角函数 用js在三角函数布置表盘的过程中有遇见到这种情况 ...
- 浅谈数据结构之KMP(串中的模式匹配算法)
KMP算法是一种模式匹配算法的改进版,其通过减少匹配的次数以及使主串不回朔来减少字符串匹配的次数,从而较少算法的相应代价,但是,事件万物是普遍归中的,KMP算法的有效性也是有一定的局限的,我将在本文的 ...
- 浅谈时钟的生成(js手写代码)(非原创)
在生成时钟的过程中自己想到布置表盘的写法由这么几种: 当然利用那种模式都可以实现,所以我们要用一个最好理解,代码有相对简便的方法实现 1.利用三角函数 用js在三角函数布置表盘的过程中有遇见到这种情况 ...
- 浅谈JavaScript的面向对象和它的封装、继承、多态
写在前面 既然是浅谈,就不会从原理上深度分析,只是帮助我们更好地理解... 面向对象与面向过程 面向对象和面向过程是两种不同的编程思想,刚开始接触编程的时候,我们大都是从面向过程起步的,毕竟像我一样, ...
- 浅谈php生成静态页面
一.引 言 在速度上,静态页面要比动态页面的比方php快很多,这是毫无疑问的,但是由于静态页面的灵活性较差,如果不借助数据库或其他的设备保存相关信息的话,整体的管理上比较繁琐,比方修改编辑.比方阅读权 ...
- SDUT OJ 数据结构实验之串一:KMP简单应用 && 浅谈对看毛片算法的理解
数据结构实验之串一:KMP简单应用 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descr ...
随机推荐
- memcached简介(转)
背景 memcached是一个高性能.分布式的内存对象缓存系统. memcached广泛应用在大负载高并发的网站上,是一种非常成熟的产品(称为一项技术也未尝不可).像facebook,yout ...
- JQuery 常用方法基础教程
本文转自(http://www.cnblogs.com/Leo_wl/archive/2010/06/22/1762401.html) 对于学习使用jquery 的朋友,能用的到,简单的了解下jque ...
- svn 提交错误 400 Bad Reqest MKACTIVITY 请求于XX失败 Conflict Unable to connect to a repository at URL
思路来源:http://www.cnblogs.com/wangyt223/archive/2012/11/22/2782801.html svn 提交错误 400 Bad Reqest MKACTI ...
- [JS]学习Javascript闭包(Closure)
转自:阮一峰 闭包(closure)是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现. 下面就是我的学习笔记,对于Javascript初学者应该是很有用的. 一.变量的 ...
- PLSQL_基础系列07_插入方式Pivoting / Unconditional / Conditional ALL / Conditional FIRST INSERT(案例)
2014-12-08 Created By BaoXinjian
- [Tex学习]给汉字注音
\documentclass{article} \usepackage[CJK]{ruby} \usepackage{pinyin} \begin{document} \begin{CJK*}{GBK ...
- 编写第一个java程序
安装了一个编辑器,Notepad++,这个编辑器以前在写PHP的时候就喜欢用,呵呵,现在写java也先沿用这个这个编辑器吧. 代码: public class Test{ public static ...
- mysql基础语法之(全文索引)
1.概要 InnoDB引擎对FULLTEXT索引的支持是MySQL5.6新引入的特性,之前只有MyISAM引擎支持FULLTEXT索引.对于FULLTEXT索引的内容可以使用MATCH()…AGAIN ...
- 30天轻松学习javaweb_http头信息实例
package com.wzh.test.http; import java.io.ByteArrayOutputStream;import java.io.IOException;import ja ...
- 30岁IT男连续工作一个月 突然失聪
连续开发软件一个月,30 岁男子突然听不见声音了.近日,浙江省中山医院针灸科主任高宏主任中医师接诊了这名患者.高主任说,现在很多年轻人工作压力大,得突发性耳聋的越来越多,这种病听着不是威胁生命的大病, ...