EntityViewInfo包含了FilterInfo(过滤)、Selector(指定属性)以及Sorter(排序)

本文详细介绍了EntityViewInfo在查询接口中的应用,包括如何通过FilterInfo设置过滤条件、Selector指定查询属性以及Sorter进行排序。提供了多种场景下的具体示例,如直接获取对象信息、表头F7过滤等。

(1)EntityViewInfo常常用作bos中接口参数,来做查询用,其中包含了FilterInfo(过滤)、Selector(指定属性)以及Sorter(排序)

SelectorItemCollection sic = new SelectorItemCollection();  
 
//表示获取info所有的属性  
 
sic.add(newSelectorItemInfo("*"));  
 
//表示获取info上creator上所有的属性  
 
sic.add(newSelectorItemInfo("creator.*"));  
 
//表示只获取info上auditor上id,name和number三个属性  
 
sic.add(new SelectorItemInfo("auditor.id"));  
 
sic.add(newSelectorItemInfo("auditor.number"));  
 
sic.add(newSelectorItemInfo("auditor.name"));  

特殊的
XXXFactory.getRemoteInstance().getXXXInfo(IObjectPKpk);//直接获取info,如果info中含有关联属性,只能取到关联属性的ID  
 
XXXFactory.getRemoteInstance().getXXXInfo(IObjectPKpk, SelectorItemCollection selector);//直接获取Info,通过在selector中指定需要取哪些属性,比如

1、 建立过滤条件,分录上的F7过滤

KDBizPromptBox prmt = (KDBizPromptBox) this.kdtEntrys.getColumn("feeType").getEditor().getComponent();

EntityViewInfo view = new EntityViewInfo();
FilterInfo filterInfo = new FilterInfo(); // 建立过滤条件
filterInfo.getFilterItems().add(new FilterItemInfo("number", "108", CompareType.EQUALS));
view.setFilter(filterInfo);
prmt.setEntityViewInfo(view);

2、通用查询

EntityViewInfo evi = new EntityViewInfo();

SelectorItemCollection selector = evi.getSelector();

selector.add(new SelectorItemInfo("id"));
selector.add(new SelectorItemInfo("startDate"));
FilterInfo filter = new FilterInfo();
filter.getFilterItems().add(new FilterItemInfo("accountDate", endAccountDate, CompareType.GREATER));
evi.setFilter(filter);
3、跟1差不多,表头F7过滤

EntityViewInfo view = new EntityViewInfo();
FilterInfo filterInfo = new FilterInfo(); // 建立过滤条件
filterInfo.getFilterItems().add(new FilterItemInfo("number", number, CompareType.GREATER_EQUALS));
view.setFilter(filterInfo);
prmtaccountTo.setEntityViewInfo(view);
prmtaccountTo.getQueryAgent().resetRuntimeEntityView();

4、带or过滤条件,如果不设setMaskString,则默认为and

EntityViewInfo view = new EntityViewInfo();
FilterInfo filterInfo = new FilterInfo(); // 建立过滤条件
filterInfo.getFilterItems().add(new FilterItemInfo("number", "001", CompareType.EQUALS));
filterInfo.getFilterItems().add(new FilterItemInfo("number", "005", CompareType.EQUALS));
filterInfo.setMaskString("#0 or #1");//条件为or (设置过滤条件之间的关系,不设置setMaskString时,默认为and)
view.setFilter(filterInfo);
prmt.setEntityViewInfo(view);

转载于:https://www.cnblogs.com/fu512/p/6924473.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值