0

我正在尝试使用 2 个连接表进行自定义查找(在 .Net 中):

AxLookup nameLookup = e.LookupControl;
Proxy.QueryBuildDataSource emplTable = null;
Proxy.QueryBuildDataSource dirPartyTable = null;

using (Proxy.SysDataSetBuilder sysDataSetBuilder = proxy.SysDataSetBuilder.constructLookupDataSet(this.AxSession.AxaptaAdapter, TableMetadata.TableNum(this.AxSession, "EmplTable")))
{
    nameLookup.LookupDataSet = new DataSet(this.AxSession, sysDataSetBuilder.toDataSet());        
}

using (Proxy.Query query = nameLookup.LookupDataSet.DataSetViews[0].MasterDataSource.query())
{
    emplTable = query.dataSourceNo(1);
    dirPartyTable = emplTable.addDataSource(TableMetadata.TableNum(this.AxSession, "DirPartyTable"));
    dirPartyTable.clearLinks();
    dirPartyTable.addLink(TableDataFieldMetadata.FieldNum(this.AxSession, "EmplTable", "PartyId"), TableDataFieldMetadata.FieldNum(this.AxSession, "DirPartyTable", "PartyId"));                
    dirPartyTable.joinMode = 6;  //should be an exists join
}

nameLookup.LookupDataSet.Init();


nameLookup.Fields.Add(AxBoundFieldFactory.Create(this.AxSession, nameLookup.LookupDataSetViewMetadata.ViewFields["EmplId"]));
nameLookup.Fields.Add(AxBoundFieldFactory.Create(this.AxSession, nameLookup.LookupDataSetViewMetadata.ViewFields["DirPartyTable!Name"])); //not working!!

nameLookup.SelectField = "EmplId";

现在,当我使用查找时,它给了我关于 DirPartyTable 中的名称字段的错误(未找到键)有人知道如何在连接表中添加查找字段吗?

我确定连接工作正常,在连接表上进行了一些其他查找范围(当然第二个表上没有查找字段),并且工作正常。

任何帮助表示赞赏!

4

1 回答 1

1

这已在以下博客文章中进行了讨论:http: //palleagermark.blogspot.com/2009/12/data-set-lookups-on-enterprise-portal.html

答案是您不能使用与 AxLookup 控件连接的数据源,因为它是为仅支持一个 DataSetView 而构建的,如果您有多个 DataSetView 将引发此异常。

于 2012-01-11T21:11:27.380 回答