zoukankan      html  css  js  c++  java
  • EF 查询视图出现重复数据

    解决方案: 由多张表组成的视图,要加实体键。而且实体键组合要能确保唯一性。

    个人理解:确保唯一性,一个或多个实体键,实现了复合主键或组合主键的效果。

    这样查询是,延迟加载机制,才知道哪些需要重新从数据库中拿而不是缓存中。

     在思考:实体键的字段可以不是某个表的主键!?只要能确保唯一性行,其实“实体键的组合”也相当于“唯一索引”了。

    总结:在模型中,加一个或多个实体键,只要能确保唯一性就行。

    相关文章:

    EF 查询视图返回重复数据的问题

    http://www.mamicode.com/info-detail-2253463.html

    在特殊的情况下查询过滤视图 会出现重复的数据结果集(返回的多条数据结果一致)。

    原因是啥:主键

    在数据库设计的理念中:每个表都应该的唯一的主键。但视图不同,EF中会自动按视图的最前几个非空型字段设置为主键。

    技术分享图片

    如果在某些特殊的查询情况下。前几列数据一致时,EF就会返回重复数据。

    解决方案:

    1. 在使用的视图后 加入 AsNoTracking 阻止EF缓存数据集。(EF会依据主键建立数据缓存,实现后续的级联操作)。

    2. 修改视图列顺序,将能区分内容的列放入最前列中,并保证为非空类型。

    建议使用第二方案。

  • 相关阅读:
    JSON 在 IE 下不执行的问题
    一些UTF8编码问题
    如果你也想做一个Pinterest?
    关于apache虚拟机的NameVirtualHost错误
    如何玩转数据库设计
    mysql 导入数据时 max_allowed_packet 的问题
    几个练习题
    数组,for语句(补10.11)
    MySql数据库
    js基础(补10.10)
  • 原文地址:https://www.cnblogs.com/hao-1234-1234/p/10752458.html
Copyright © 2011-2022 走看看