出于各种原因,有时需要跨数据库访问某些数据表,有同学已经给出了解决方案,比如  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 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下的解决方案的更多相关文章

  1. EF 跨库查询

    原因:最近公司项目,遇到一个ef跨库查询的问题.(只是跨库,并不是跨服务器哈) 主要我们的一些数据,譬如地址,城市需要查询公共资料库. 但是本身我的程序设计采用的是ef框架的.因此为这事花费了1天时间 ...

  2. 如何使用SQL SERVER数据库跨库查询

    SQL Server中内置了数据库跨库查询功能,下面简要介绍一下SQL Server跨库查询.首先打开数据源码:OPENDATASOURCE不使用链接的服务器名,而提供特殊的连接信息,并将其作为四部分 ...

  3. mysql 跨库查询问题

    MySQL实现跨服务器查询 https://blog.csdn.net/LYK_for_dba/article/details/78180444 mysql> create database l ...

  4. SQLServer跨库查询--分布式查询(转载)

    --用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB' ,'sq ...

  5. 2017.9.15 postgres使用postgres_fdw实现跨库查询

    postgres_fdw的使用参考来自:https://my.oschina.net/Kenyon/blog/214953 postgres跨库查询可以通过dblink或者postgres_fdw来完 ...

  6. oracle使用dblink跨库查询的例子

    本文介绍了oracle数据库使用dblink进行跨库查询的方法,oracle dblink跨库查询教程,需要的朋友参考下.   oracle dblink跨库查询 方法一:首先,创建数据库链接: 复制 ...

  7. SqlServer跨库查询

    由于业务的拆分,数据库拆分为两种作用: 汇总数据库(Master,头节点数据库), 子节点数据库(Compute Node,计算子节点数据库) 这样,就设计到子节点访问头节点数据库中的某张汇总表,这种 ...

  8. ACCESS-如何多数据库查询(跨库查询)

    测试通过:ACCESSselect * from F:\MYk.mdb.tablename说明:1.查询语句2.来原于哪(没有密码是个路径)3.查询的表名 ====================== ...

  9. Access数据库跨库查询及记录集区分

    医疗设备软件一般都是单机软件,如果是Windows平台,常会选择Access数据库存储结构化数据,因为他轻量,便于部署.然而随着医疗信息化的发展,医生希望对多台单机设备的数据进行管理,采用网络数据库当 ...

随机推荐

  1. hbase的写和读,大合并和小合并

    Hbase写: 客户端向hbase服务器端发送写的请求时,hbase会同时进行两个动作,把记录写在WAL(write ahead log)日志文件中,每台服务器所有表都共享这个WAL文件.然后会写到m ...

  2. Exception in thread "main" java.lang.UnsatisfiedLinkError: org.apache.hadoop.io .nativeio.NativeIO$Windows.createDirectoryWithMode0(Ljava/lang/String;I)V

    首先,遇到这个问题的一个原因是windows环境中没有配置hadoophome.配置之后加入winutils工具 第二个原因,pom中执行的hadoop的版本与window环境中的hadoop的版本不 ...

  3. 【微信小程序】scroll-view与Page下拉冲突

    需求:主界面是个列表.列表可以纵向滑动,下拉添加新的条目Item.每个条目Item可以横向滑动. 发现做下拉时,用Page的enablePullDownRefresh和scroll-view条目的横向 ...

  4. MyEclipse10中配置开发Python所需要的PyDev 绝对靠谱 不忽悠!

    在NLP(自然语言处理)这个领域中,Python具有良好的声誉,于是也想学习一下.首先第一步就是需要在计算机上配置Python环境.由于Python自带的编辑器太简单,使用起来不顺手,于是就考虑在相对 ...

  5. [算法]谷歌笔试题:Beautiful Numbers

    题目描述 思路 这道题就是在说,由多个1组成的数是beautiful的,现在想求出r进制中的r,使得给出的数字转换成r进制,得到beautiful的数字,如果有多种方式转换,那么取1的个数最多的那种情 ...

  6. Android7.0 Doze模式分析(一)Doze介绍 &amp; DeviceIdleController

     參考:http://blog.csdn.net/gaugamela/article/details/52981984 在Android M中.Google就引入了Doze模式.它定义了一种全新的 ...

  7. oracle的启动和停用

    1.开始-运行-cmd-确定 2.cmd页面,输入set ORACLE_SID=(你的数据库实例名),回车,执行 3.继续输入‘sqlplus/nolog’,敲击回车键 4.sql输入栏,输入‘con ...

  8. 链接按钮LinkButton(按钮组)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  9. jquery 利用CSS 控制打印样式

    一.添加打印样式 1. 为屏幕显示和打印分别准备一个css文件,如下所示:  用于屏幕显示的css: <link rel="stylesheet" href="cs ...

  10. 在C++中调用DLL中的函数(3)

    1.dll的优点 代码复用是提高软件开发效率的重要途径.一般而言,只要某部分代码具有通用性,就可将它构造成相对独立的功能模块并在之后的项目中重复使用.比较常见的例子是各种应用程序框架,ATL.MFC等 ...