XAF-列表视图数据访问模式
本主题介绍有关列表视图如何提供数据访问的几种方式。请注意,选择正确的方式对于实现XAF应用程序的最佳性能至关重要。
数据访问模式概述
在模型编辑器中,通过 视图-> <ListView>节点找到IModelListView.DataAccessMode属性,指定显示的对象集合是如何被访问。可用值- Client,Server,InstantFeedback和DataView。
当通过使用IModelListView.EditorType属性设置了不同的编辑器时,DataAccessMode中的值并不会隐藏掉不支持的模式。
如果您使用自定义列表编辑器,您可以通过静态方法DataAccessModeHelper.RegisterEditorSupportedModes指定支持的模式。
您可以在加载模型编辑器之前(例如,从模块的构造函数)在设计时执行的任何代码调用此方法。将列表编辑器类型及其支持的模式列表传递到此方法。默认情况下,所有模式都可用于自定义列表编辑器。
默认模式是Client,这在大多数情况下,适当的使用Server,InstantFeedback和DataView模式是提升性能问题的好方法,但它们使用不同的优化方法。下表提供了每种模式的详细说明。
Client: 在显示列表时,一次性的将数据库中的所有记录都读到客户端(win是客户端,web是读取web服务器内存中),不管界面上显示了多少数据,都先放到内存中去。执行排序、分组、分页、过滤,时,都是去操作内存数据。 这看起来不错吧,然后,在数据很多,关联很复杂时,一次性加载这么多会让我们感覺很慢(比如几万条),也很占内存。 |
Server: 假设我们使用的是sql数据库(oracle,mysql,mssql都算上),这种模式是使用sql语句进行分组、分页、排序、过滤的,这样会让数据不需要全部返回,数据多时,压力转移到sql服务器。只加载显示出来的部分,或一小部分数据,每次需要时,再去读取。数据量大时,比起client快很多。
实际使用中,遇到的较多的问题是:属性不是持久化的,不支持过滤、排序功能。可以考虑用PersistentAlias来做服务端计算表达式,用了这个之后,我们基本可以放弃要使用sql语句的功能了。 |
InstantFeedback: 此模式与服务器模式非常相似。所不同的是, 该数据感知操作在后台线程异步执行(16.X中的新功能),并且控制继续响应于用户的操作,而被检索到的数据(见即时反馈模式)。这就是为什么上述常规(同步)服务器模式的限制也适用于即时反馈的原因。附加限制:
|
DataView: 一次性加载所有的数据,但不是转换为ORM对象,返回的是数组。
|
- 您可以全局的修改所有列表视图(除了自动生成的嵌套列表视图)的数据访问方式,设置IModelOptions.DataAccessMode的属性选项节点即可。
- 所有手动创建的列表视图,包括嵌套的列表视图,默认使用IModelListView.DataAccessMode属性值。
- 在代码中创建CollectionSource并应用于ListView时,您可以使用CollectionSource.CollectionSource的构造函数中的dataAccessMode参数来指定模式。
当你定义了一个集合属性,但并没有使用Association建立关系时,你应该使用Client模式,因为,没办法推导出如何过滤这个集合。
啥意思呢,你直接在代码写了个集合属性:return new XPCollection<T>("条件");
XAF不可能使用服务端模式,因为“条件”是怎么来的,是不可以确定的,不可以自动推算出来的,比如你是动态变化的,XAF也不知是啥规则。
使用Server、InstantFeedback或DataView模式时,想显示非持久化属性时,应该用PersistentAliasAttribute或CalculatedAttribute属性。
如何选择合适的数据访问模式
服务器,InstantFeedback和数据视图模式旨在改善列表视图的性能,但应根据不同的场景。
如果数据库请求数量是关键问题时,那么就应该选择DataView模式。在此模式下,所有数据记录只请求一次,然后在客户端执行分组,排序和过滤,无需额外请求。引用类型的属性也会一次加载过来,产生的SQL就是left join。在DataView模式,只加载界面可见的列,如果理解成sql语句,则是 select a,b,c from xx ,而其他模式(Client和Server)则是加载所有的列,则是select * from xx *还有可能是更多,也会产生更多次请求,比如没有设置显示的加载引用型属性,就会再生成几次引用属性的加载。
如果列表视图启动时间非常重要,那么你应该选择Server或InstantFeedback模式。在这些模式下,只有可见的对象都被第一次请求时加载。然而,滚动、 分组、 排序和筛选导致附加的数据库请求-则是按需加载数据。
如果性能还不错,只需使用Client模式。不要启用Server,InstantFeedback或DataView,除非你发性能不能接受,或是找到了合适的模式时。务必记住本主题前面列出的限制。需要注意的是如果数据很少,Server和InstantFeedback模式并没有什么意义。
转载于:https://www.cnblogs.com/foreachlife/p/xafdataaccessMode.html
XAF-列表视图数据访问模式相关推荐
- 数据访问模式二:数据集和数据适配器(传统的数据访问模式)
上一篇文章介绍了使用DataSource控件访问数据库的过程,本节介绍利用数据适配集/数据适配器的访问数据库.这两种设计模式的差别,使得GridView的设计即要支持DataSource控件的数据绑定 ...
- 关于数据访问模式(三)—— Data Accessor模式
拐弯抹角了两篇Post,说了一下重要性和很常见的一个词汇:Metadata,终于都到言归正传的时候了.今天我们先来看看数据访问模式当中使用得很频繁的一种模式--Data Accessor(也称为DAO ...
- Scott Mitchell 的ASP.NET 2.0数据教程之一: 创建一个数据访问层
原文 | 下载本教程中的编码例子 | 下载本教程的英文PDF版 导言 作为web开发人员,我们的生活围绕着数据操作.我们建立数据库来存储数据,写编码来访问和修改数据,设计网页来采集和汇总数据.本文是研 ...
- idata 数据访问组件库 (2021版)
idata数据访问组件库(RX11)版本: 2022-09-20 下载: idata 数据组件库 for RAD Studio RX10.3.x (260) 发布于:2020-02-20 使用 ...
- ASP.NET数据库访问系列教程01-概述篇 创建数据访问层(中)
ASP.NET数据库访问系列教程 本教程深入探讨了基于ASP.NET 2.0技术的数据库访问方法和模式.这些介绍非常简明,并且提供了一步步的指导和大量的截屏. 该系列教程包括: 概述篇 基础报表 主/ ...
- Java数据访问对象模式
数据访问对象模式(Data Access Object Pattern)或 DAO 模式用于把低级的数据访问 API 或操作从高级的业务服务中分离出来.以下是数据访问对象模式的参与者. 数据访问对象接 ...
- Entity Framework技术系列之2:三种开发模式实现数据访问
前言 Entity Framework支持Database First.Model First和Code Only三种开发模式,各模式的开发流程大相径庭,开发体验完全不一样.三种开发模式各有优缺点,对 ...
- arcgis adf数据_使用ADF列表视图的主从数据
arcgis adf数据 从UI角度来看,最近ADF Faces 表组件不再被认为很酷. 对于显示数据集合, 列表视图今天应该很酷. 这并不意味着我们根本不应该使用af:table . 在某些情况下( ...
- 使用ADF列表视图的主从数据
最近,从UI角度来看,ADF Faces 表组件不再被认为很酷. 对于显示数据集合, 列表视图今天应该很酷. 这并不意味着我们根本不应该使用af:table . 在某些情况下(经常是:)),表比列表视 ...
最新文章
- Deep learning的一些教程 (转载)
- Mysql data type
- 王者权志龙回归!支持爱豆壁纸少不了
- React入门第一天(绑定事件,动态渲染,修改样式、传参)
- UAT测试后上线出现问题的引起的思考
- 软件测试工程师APUS一面二面汇总
- HDU3966 树链剖分
- 登录失败 12306服务器不稳定,12306无法正常登录怎么办?12306登陆不上的解决方法...
- C语言及程序设计[套餐]课程主页
- 4094. Spiral matrix
- 自定义CollapsingToolbaLayout完成可收缩的带头像的Toolbar
- YYText-显示富文本
- 在Outlook2007中设置QQ邮箱为IMAP/SMTP服务器
- linux 命令行退出某条命令
- 国内下载android源码,Android国内源码下载——亲测成功-Go语言中文社区
- 图像处理反向投影原理
- 【bzoj2434】阿狸的打字机 AC自动机+树状数组
- vs code编写web项目
- Ubuntu环境QT出现:-1: error: cannot find -lGL(已解决)
- WebStorm配置eslint检查自动格式化(自动解决eslint问题\Vue3项目解决ESLint问题)
热门文章
- python web开发c6——阿里云上ubuntu+flask+gunicorn+nginx服务器部署(一)简单测试
- es6=unicode码详解
- bzoj1083 [SCOI2005]繁忙的都市(最小生成树)
- 人民币 小写金额转换为大写金额
- NSOperation队列实实现多线程
- Android -- 重置Bitmap大小Bitmap转角度
- 澳门大学物联网设计方法研究获“973”立项
- FAIR 何恺明、Piotr、Ross等新作,MAE才是YYDS!仅用ImageNet1K,Top-1准确率87.8%!
- WenLan-10亿参数!别只玩GPT,来看看人大中科院联手打造第一个大规模多模态中文预训练模型BriVL...
- 25-60k/m | 湃道智能招聘