• EDMX更新实体后出现键值映射问题


    近期做项目的EF改版时,在DB(ORACLE)中的表里添加一个新的PK,去除原有的PK。

    在DB已添加完成操作,但这时在EDMX里进行从DB更新到EF里,更新完成后就发生如下错误提示:

    Error 6 Error 3002: Problem in mapping fragments starting at line 8140:Potential runtime violation of table EXAMINE_MAIN's keys (EXAMINE_MAIN.MID): Columns (EXAMINE_MAIN.MID) are mapped to EntitySet EXAMINE_MAIN's properties (EXAMINE_MAIN.MID) on the conceptual side but they do not form the EntitySet's key properties (EXAMINE_MAIN.EXAMINEID, EXAMINE_MAIN.MID).
    D:130ProjecteMBSCenterEFDataProviderOralceEntitiesEntities.edmx 8141 8186 EFDataProvider

    中文意思大概是:

    OralceEntities.Entities.msl(806,10) : 错误 3002: 映射从第 806 行开始的片段时有问题:表 EXAMINE_MAIN 的键(EXAMINE_MAIN.MID)具有潜在运行时冲突: 列(EXAMINE_MAIN.MID)映射到概念端 EntitySet EXAMINE_MAIN 的属性(EXAMINE_MAIN.MID),但是它们未形成 EntitySet 的键属性(EXAMINE_MAIN.EXAMINEID, EXAMINE_MAIN.MID)。

    处理方案:

      导致原因:PK对应在EDMX里的属性为实体键,实际上此时的这张表已存在两个实体键(也就是说存在了两个PK),在T4模板了自然也会生成两个PK的值。这样就会发生冲突了!

      知道这个原因后估计我不说你也知道该怎么处理了吧?

      很简单,找的更新后的这张实体表,找出原来的PK ,按F4,把实体键设置为False,再重新编译即可。(附图)

      

      

  • 相关阅读:
    微软免费人工智能课程
    如何定义,创建,启动一个线程
    什么是进程,什么是线程?
    Hashtable 数据遍历的几种方式
    action中result没有值
    <global-results>怎么用
    普通请求和ajax请求的区别
    result默认返回action中的所有数据,要想返回指定的数据怎么做呢
    ajax技术的应用?
    什么是国际化
  • 原文地址:https://www.cnblogs.com/byvar/p/3644558.html
Copyright © 2020-2023  润新知