• EntiyFramework :Update model from database引起的两个问题


    EntiyFramework一大特点就是Code first,但难免有时候因特殊原因需要Update model from database。此次使用该功能时遇到两个问题,且记之。

    [问题一]

      Error 3027: No mapping specified for the following EntitySet/AssociationSet - XXXXXXX.

    [起因]

       在数据库新建一张表,并使用Update model from database功能同步到EF, Add Association后,发生该错误。

    [说明]

       XXXXXXX代表关系名称,例如一个外键关系:FK_Bug_TestCase。

    [原因]

      在EF中Add Association时,.edmx文件并未被同步创建。

    [解决方案]

      Step1:右键.edmx文件,以XML Editor方式打开,如下图:

      Step2:ctrl+F 搜索,找到名称为XXXXXXX的Asscoiation节点,以FK_Bug_TestCase为例,并添加<ReferentialConstraint></ReferentialConstraint>节点,并设置Principal的Role属性为主键表名,子节点PropertyRef的Name属性为主键表用作外键的字段名;设置Dependent的Role属性为外键表名,  子节点PropertyRef的Name为外键字段名。如下图所示:

      Step3:保存即可。

     

    [问题二]

       Unable to update the EntitySet 'Bug' because it has a DefiningQuery and no <InsertFunction> element exists in the <ModificationFunctionMapping> element to support the current operation.

    [起因]

      在问题一已解决的前提下,对数据库进行更新是引起。

    [原因]

      使用Update model from database功能时,EF在.edmx文件里创建了< DefiningQuery ></ DefiningQuery >节点。DefiningQuery 节点的作用,MSDN解释如下:A defining query is commonly used to provide functionality similar to that provided by a database view, but the view is defined in the model, not the database.

    [解决方案]

      Step1:同问题一Step1,以XML Editor方式打开.edmx文件。

      Step2:ctrl+F 搜索,找到名称为DefiningQuery的节点(其实一眼就可以看出来它所在EntitySet跟别的EntitySet的不同,用的时候就看到了),并删除。此外对其所在EntitySet节点的Store:Schema属性的Store:命名空间去掉,并删除Store:Name属性。如下图所示:

      修改前:

    修改后:

      Step3:保存即可。

  • 相关阅读:
    用原生JS判断素(质)数,并找出100~1000之间的所有素(质)数
    用原生JS找出所有的水仙花数
    break、continue和return语句的区别
    用原生JS写16进制随机颜色
    JavaScript函数
    JavaScript数组
    JavaScript流程控制
    新的开始,新的历程
    异常处理
    DictionaryBase
  • 原文地址:https://www.cnblogs.com/yuanlb/p/3029238.html
Copyright © 2020-2023  润新知