在Entity Framework中重用现有的数据库连接字符串
2024-10-08 23:08:41
本文转载:http://www.cnblogs.com/dudu/archive/2011/01/29/entity_framework_connection_string.html
如果EF在使用实体模型时候,即model first 和db first 时候,则
Entity Framework使用的连接字符串与ADO.NET是不同的,见下图:
相比于ADO.NET,Entity Framework的连接字符串不仅要存放metadata配置信息,还要存放完整的数据库连接字符串(上图中的"provider connection string"部分)。
这样的设计有两个不足之处:
1. 连接字符串配置复杂;
2. 无法重用现有的ADO.NET数据库连接字符串。
我在技术推广中这么写的:
public class DALBase
{
public NWEntities NWContext { get; set; } public DALBase()
{
string providerString = ConfigurationManager.ConnectionStrings[connectionStringName].ConnectionString;
string conn = GetEntityConnString(providerString);
NWContext = new NWEntities(conn);
} private string GetEntityConnString(string providerString)
{
EntityConnectionStringBuilder entityBuilder = new EntityConnectionStringBuilder();
//Metadata属性的值,是从向导生成的Config粘贴过来的
entityBuilder.Metadata = "res://*/NW.csdl|res://*/NW.ssdl|res://*/NW.msl";
entityBuilder.ProviderConnectionString = providerString;
entityBuilder.Provider = "System.Data.SqlClient"; return entityBuilder.ToString();
}
}
注意上面中的 entityBuilder.Metadata = "res://*/NW.csdl|res://*/NW.ssdl|res://*/NW.msl";
metadata:指明.csdl/.ssdl/.msl三个文件的路径,要与你的edmx文件名称一致。
web.config文件如下:
Entity FreamWork配置文件方式
<add name="LGSCMSEntities" connectionString="metadata=res://*/Model1.csdl|res://*/Model1.ssdl|res://*/Model1.msl;provider=System.Data.SqlClient;provider connection string="Server=zengfanlong;database=LGSCMS;uid=sa;pwd=123456;"" providerName="System.Data.EntityClient" /> ADO.NET方式配置文件
<add name="LGSCMSEntities" connectionString="Server=zengfanlong;database=LGSCMS;uid=sa;pwd=123456;"/>
最新文章
- ASP.NET MVC之路由特性以及母版页呈现方式(十二)
- 关于《Windows程序设计(第五版)》中一个实例程序的疑问
- AngularJS从构建项目开始
- 【转】require.js学习笔记(二)
- 使用javamail发送邮件错误:550 5.7.1 Unable to relay
- [转]ThreadPoolExecutor线程池的分析和使用
- bzoj2743 [HEOI2012]采花
- AP_AP系列 - 发票管理分析(案例)
- ubuntu安装mysql5.7
- awk的二维数组
- WS103C8例程——串口2【worldsing笔记】
- [转]使用ADO.NET访问Oracle存储过程
- OcciWrapper使用指南(高性能Oracle访问组件)
- linux进程创建
- 自制单片机之一------AT89S51最小系统制做
- 射频识别技术漫谈(27)——CPU卡概述
- 【jQuery】smartMenu右键自定义上下文菜单插件(似web QQ)
- Tornado异步
- node平台的安装与搭建
- ProgressBar 进度条开源项目总结