EF跨库查询,DataBaseFirst下的解决方案
出于各种原因,有时需要跨数据库访问某些数据表,有同学已经给出了解决方案,比如 http://blog.csdn.net/hanjun0612/article/details/50475800 已经解决了code first 下跨数据库访问。但是如果已经是通过数据库创建的模型用此方法。报错xxxxxxxx。经过摸索下面给出DataBase First 下的解决方案
一、创建同义词
本例中以查询银企互联系统中某用户代码表为例 BankDirectLinkEnterprise为 数据库名 CustromerCode 数据表名 BDE_CustomerCode为同义词名
1
|
CREATE SYNONYM [dbo].[BDE_CustomerCode] FOR [BankDirectLinkEnterprise].[dbo].[CustomerCode]<br> --表结构如下 |
CREATE TABLE [dbo].[CustomerCode](
[ID] [int] IDENTITY(1,1) NOT NULL,
[Code] [nvarchar](50) NULL,
[ReceivedCustomerID] [int] NULL,
[Name] [nvarchar](50) NULL,
[IsPrimary] [bit] NULL,
[IsChargeCode] [bit] NULL,
CONSTRAINT [PK_CustomerCode] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
如果数据库不在一个服务器下,请参见 http://blog.csdn.net/fanbin168/article/details/51104990 文中解决
二、仔细审视项目中 xxxx.edmx文件
用xml文本编辑器打开xxxx.demx文件我们发现其结构大致可分为4部分
1.描述了数据库定义、2、描述了类定义、3、关联类与数据库、4、描述如果显示类图位置,具体见图(图中描述类与数据库定义写反了,见谅)
、
大概看懂之后就备份了一下,按需求改动
2、增加数据库中的表定义 在 <edmx:StorageModels> <Schema> 节点中加入以下代码
< EntityType Name="BDE_CustomerCode"> < Key > < PropertyRef Name="ID" /> </ Key > < Property Name="ID" Type="int" StoreGeneratedPattern="Identity" Nullable="false" /> < Property Name="Code" Type="nvarchar" MaxLength="100" /> < Property Name="Name" Type="nvarchar" MaxLength="100" /> < Property Name="ReceivedCustomerID" Type="int" /> < Property Name="IsPrimary" Type="bit" /> < Property Name="IsChargeCode" Type="bit" /> </ EntityType > |
增加容器定义 <edmx:StorageModels><Schema> <EntityContainer>节点下添加(虽然这个同义词在数据库中不存在,但是按其在原数据库中的类型来添加,一点问题没有)
1
|
< EntitySet Name="BDE_CustomerCode" EntityType="Self.BDE_CustomerCode" Schema="dbo" store:Type="Tables" /> |
3、增加数据定义, 在 <edmx:ConceptualModels><Schema>节点中加入以下代码
1
2
3
4
5
6
7
8
9
10
11
|
< EntityType Name="BDE_CustomerCode"> < Key > < PropertyRef Name="ID" /> </ Key > < Property Name="ID" Type="Int32" Nullable="false" annotation:StoreGeneratedPattern="Identity" /> < Property Name="Code" Type="String" MaxLength="100" FixedLength="false" Unicode="true" /> < Property Name="Name" Type="String" MaxLength="100" FixedLength="false" Unicode="true" /> < Property Name="ReceivedCustomerID" Type="Int32" /> < Property Name="IsPrimary" Type="Boolean" /> < Property Name="IsChargeCode" Type="Boolean" /> </ EntityType > |
增加容器定义 <edmx:ConceptualModels><Schema> <EntityContainer>节点下添加
1
|
< br >< EntitySet Name="BDE_CustomerCodes" EntityType="DB_OnlineOrderModel.BDE_CustomerCode" /> |
DB_OnlineOrderModel为此项目的model命名空间,大家按自己项目改掉
3、增加数据定义与数据库映射 <edmx:Mappings> Mapping节点下添加
1
2
3
4
5
6
7
8
9
10
11
12
|
< EntitySetMapping Name="BDE_CustomerCodes"> < EntityTypeMapping TypeName="DB_OnlineOrderModel.BDE_CustomerCode"> < MappingFragment StoreEntitySet="BDE_CustomerCode"> < ScalarProperty Name="Code" ColumnName="Code" /> < ScalarProperty Name="ReceivedCustomerID" ColumnName="ReceivedCustomerID" /> < ScalarProperty Name="Name" ColumnName="Name" /> < ScalarProperty Name="IsPrimary" ColumnName="IsPrimary" /> < ScalarProperty Name="IsChargeCode" ColumnName="IsChargeCode" /> < ScalarProperty Name="ID" ColumnName="ID" /> </ MappingFragment > </ EntityTypeMapping > </ EntitySetMapping > |
4找个位置显示它 <edmx:Designer> <edmx:Diagrams> <edmx:Diagram> 添加一条,如果不知道后面的pointx pointy 如何写,照葫芦画瓢后可调整
<edmx:EntityTypeShape EntityType="DB_OnlineOrderModel.BDE_CustomerCode" Width="1.875" PointX="14.5" PointY="0.625" />
5,关闭edmx文件,然后双击demx文件打开它,保存,这时vs一般会再按t4模版生成代码。完毕之后就可以调用了
6,使用
1
2
3
4
5
6
7
8
9
|
var list = ( from p in this .db.BDE_CustomerCodes where p.Name.Contains(q) || p.Code.Contains(q) select new { CompanyName = p.Name, CustomerCode = p.Code }).ToList(); return Json(list, JsonRequestBehavior.AllowGet); |
好了,方案完成了,但是此方案缺点还是很明显的,人工干预的过程太多了,哪一环节出了问题都会引发错误。要是能自动化支持同义词就更好了。
EF跨库查询,DataBaseFirst下的解决方案的更多相关文章
- EF 跨库查询
原因:最近公司项目,遇到一个ef跨库查询的问题.(只是跨库,并不是跨服务器哈) 主要我们的一些数据,譬如地址,城市需要查询公共资料库. 但是本身我的程序设计采用的是ef框架的.因此为这事花费了1天时间 ...
- 如何使用SQL SERVER数据库跨库查询
SQL Server中内置了数据库跨库查询功能,下面简要介绍一下SQL Server跨库查询.首先打开数据源码:OPENDATASOURCE不使用链接的服务器名,而提供特殊的连接信息,并将其作为四部分 ...
- mysql 跨库查询问题
MySQL实现跨服务器查询 https://blog.csdn.net/LYK_for_dba/article/details/78180444 mysql> create database l ...
- SQLServer跨库查询--分布式查询(转载)
--用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB' ,'sq ...
- 2017.9.15 postgres使用postgres_fdw实现跨库查询
postgres_fdw的使用参考来自:https://my.oschina.net/Kenyon/blog/214953 postgres跨库查询可以通过dblink或者postgres_fdw来完 ...
- oracle使用dblink跨库查询的例子
本文介绍了oracle数据库使用dblink进行跨库查询的方法,oracle dblink跨库查询教程,需要的朋友参考下. oracle dblink跨库查询 方法一:首先,创建数据库链接: 复制 ...
- SqlServer跨库查询
由于业务的拆分,数据库拆分为两种作用: 汇总数据库(Master,头节点数据库), 子节点数据库(Compute Node,计算子节点数据库) 这样,就设计到子节点访问头节点数据库中的某张汇总表,这种 ...
- ACCESS-如何多数据库查询(跨库查询)
测试通过:ACCESSselect * from F:\MYk.mdb.tablename说明:1.查询语句2.来原于哪(没有密码是个路径)3.查询的表名 ====================== ...
- Access数据库跨库查询及记录集区分
医疗设备软件一般都是单机软件,如果是Windows平台,常会选择Access数据库存储结构化数据,因为他轻量,便于部署.然而随着医疗信息化的发展,医生希望对多台单机设备的数据进行管理,采用网络数据库当 ...
随机推荐
- python.pandas read and write CSV file
#read and write csv of pandasimport pandas as pd goog =pd.read_csv(r'C:\python\demo\LiaoXueFeng\data ...
- [转]html页面调用js文件里的函数报错onclick is not defined处理方法
原文地址:http://blog.csdn.net/ywl570717586/article/details/53130863 今天处理html标签里的onclick功能的时候总是报错:Uncaugh ...
- Visual Studio的NuGet包管理器无法加载
由于网络原因,虽然地址http://www.nuget.org和https://www.nuget.org/api/v2/在浏览器可以正常打开,但是在VS中使用默认的NuGet程序包源经常加载不出来, ...
- Linux shell while
sh count=1 while [ $count -le 5 ]; do echo 1234567890abcdefghqwertyuiopdasdk > /dev/ttyS1 & e ...
- ubuntu 安装 mkfs.ubifs
ubi 文件系统的制作需要 mkfs.ubifs 工具 但是又没有直接的 sudo apt-get install , 只能通过以下方式 sudo apt-get install mtd-utils
- 学习MongoDB(二) Replica Set集群配置
1.官方网址:https://docs.mongodb.org/manual/tutorial/deploy-replica-set-for-testing/ 2.Replica Set介绍: htt ...
- 【C】——动态库中函数的作用范围
如何生成动态库 net小伙 已经在此文中说明——[C]——如何生成静态库和动态库:接下来就要看看动态库中函数的作用范围: 首先我们使用命令 gcc -fPIC -shared -o libtest ...
- 给data设置数据
console.log(JSON.stringify(that.data.navigator[0].content) + "--____+" + JSON.stringify(th ...
- USB学习笔记连载(十一):CY7C68013A的启动方式-EEPROM
上述的应用笔记中有介绍FX2LP的启动选项,主要包括I2C启动和USB启动. 说白了I2C启动需要使用外部的EEPROM,USB启动,只是使用上位机控制软件将配置程序FX2LP中,不用EEPRO ...
- ESD保护芯片BAT54S/BAV99和电平转换芯片SN74AVC1T45
如下两图是terasic公司DE2-115部分原理图截图,其中有两个芯片引起了笔者的注意,一个是SN74AVC1T45和BAT54S,下面说说这两个芯片利用的好处和借鉴之处. 先讲一下BAV99.手册 ...