金蝶云星空 二开得到来源单单据体2数据包

csharp 复制代码
/// <summary>
/// 得到来源单单据体2数据包
/// </summary>
/// <param name="lstSrcPkValues"></param>
/// <param name="srcBInfo"></param>
/// <param name="srcEntity2"></param>
/// <returns></returns>
private DynamicObjectCollection GetEntity2DynamicObjs(List<long> lstSrcPkValues, BusinessInfo srcBInfo, Entity srcEntity2)
{
    QueryBuilderParemeter queryParam = new QueryBuilderParemeter();
    queryParam.FormId = srcBoFormId;// "SAL_PriceList";  // 源单据的FormId
    List<SelectorItemInfo> lstItems = new List<SelectorItemInfo>();
    lstItems.Add(new SelectorItemInfo("FID")); 
    lstItems.Add(new SelectorItemInfo("FNUMBER")); 
    lstItems.Add(new SelectorItemInfo("F_BHR_VIEWUSERS"));
    queryParam.SelectItems = lstItems; //需要选择的字段列表集合
    var tupleFilterInfo = this.GetFilter(srcBInfo.GetForm().PkFieldName, lstSrcPkValues);
    queryParam.FilterClauseWihtKey = string.Format(" {0} and {1} != 0", tupleFilterInfo.Item1, srcEntity2.EntryPkFieldName);
    queryParam.SqlParams.AddRange(tupleFilterInfo.Item2);
    var dynObjs = QueryServiceHelper.GetDynamicObjectCollection(this.Context, queryParam);
    return dynObjs;
}
/// <summary>
/// 得到过滤条件和参数
/// </summary>
/// <param name="pkFieldName"></param>
/// <param name="entryPkName"></param>
/// <param name="lstSrcPkValues"></param>
/// <returns></returns>
private Tuple<string, List<SqlParam>> GetFilter(string pkFieldName, List<long> lstSrcPkValues)
{
    string filter = string.Empty;
    List<SqlParam> lstParams = new List<SqlParam>();
    var arrPkValues = lstSrcPkValues.Distinct().ToArray();
    if (arrPkValues.Length == 1)
    {
        filter = string.Format("{0} = {1} ", pkFieldName, arrPkValues[0]);
    }
    else if (arrPkValues.Length <= 50)
    {
        filter = string.Format("{0} in ({1}) ", pkFieldName, string.Join(",", arrPkValues));
    }
    else
    {
        var cardSql = StringUtils.GetSqlWithCardinality(arrPkValues.Length, "@PKValue", 1, false);
        filter = string.Format("  EXISTS ( {0} where b.FID = {1})  ", cardSql, pkFieldName);
        lstParams.Add(new SqlParam("@PKValue", KDDbType.udt_inttable, arrPkValues));
    }
    return Tuple.Create<string, List<SqlParam>>(filter, lstParams);
}

设置 多选基础资料字段值

csharp 复制代码
  private void FieldSetValue(Context ctx, MulBaseDataField field, DynamicObject entityObj, object[] pkValues)
  {
      // 获取多选基础资料字段的数据包集合
      var mulBaseDataEntitySet = field.GetFieldValue(entityObj) as DynamicObjectCollection;
      //var mulBaseDataEntitySet = entityObj[field.PropertyName] as DynamicObjectCollection;
      if (mulBaseDataEntitySet == null)
      {
          mulBaseDataEntitySet = new DynamicObjectCollection(field.RefEntityDynamicObjectType, entityObj);
          field.RefEntityDynamicProperty.SetValue(entityObj, mulBaseDataEntitySet);
      }
      mulBaseDataEntitySet.Clear();
      // 从数据库读取指定的基础资料的数据包,并填充到当前多选基础资料字段的数据包集合中
      var baseDataObjects = BusinessDataServiceHelper.LoadFromCache(ctx, pkValues, field.RefFormDynamicObjectType);
      foreach (var baseDataObject in baseDataObjects)
      {
          var mulBaseDataEntity = new DynamicObject(field.RefEntityDynamicObjectType);
          mulBaseDataEntitySet.Add(mulBaseDataEntity);
          field.RefEntityDynamicObjectType.PrimaryKey.SetValue(mulBaseDataEntity, new SequenceReader(ctx).GetSequence<long>(field.TableName, 1).First());
          field.RefIDDynamicProperty.SetValue(mulBaseDataEntity, baseDataObject[0]);
          field.DynamicProperty.SetValue(mulBaseDataEntity, baseDataObject);
      }
  }
相关推荐
咕白m62513 小时前
.NET 环境下 Word 超链接批量提取方案
c#·.net
用户917215619021114 小时前
C# 通信协议增量解析:用状态机处理半包和粘包
c#
小码编匠1 天前
C# 工控上位机必备:数据转换工具类与十个核心模块
后端·c#·.net
唐青枫3 天前
别再乱用 StartNew:C#.NET TaskFactory 任务调度实战详解
c#·.net
Artech4 天前
[MAF预定义的AIContextProvider-03]ChatHistoryMemoryProvider——赋予Agent从经验中学习的能力
ai·c#·agent·memory·maf
Scout-leaf5 天前
C#摸鱼实录——IoC与DI案例详解
c#
咕白m6255 天前
使用 C# 在 Excel 中应用多种字体样式
后端·c#
Artech6 天前
[MAF预定义的AIContextProvider-02]AgentSkillsProvider——将Agent Skills引入MAF
ai·c#·agent·agent skills·maf
qq_369224336 天前
Windows全系通用!ntdll.dll文件丢失、报错、闪退问题的完整排查与修复教程
windows·dll·dll修复·dll丢失·dll错误
2601_962072556 天前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos