d_sms_service/APT.BaseData.Services/Services/PF/PFFormService.cs
2024-10-28 13:45:58 +08:00

2841 lines
152 KiB
C#

using APT.BaseData.Domain.ApiModel;
using APT.BaseData.Domain.Entities;
using APT.BaseData.Domain.Entities.FM;
using APT.BaseData.Domain.Entities.PF;
using APT.BaseData.Domain.Enums;
using APT.BaseData.Domain.IServices;
using APT.Infrastructure.Core;
using APT.Utility;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Linq.Expressions;
using System.Reflection;
using System.Text;
using APT.Infrastructure.Api;
namespace APT.BaseData.Services.DomainServices
{
public class PFFormService : CommonService, IPFFormService
{
/// <summary>数据库关键字</summary>
private readonly string[] DB_KEYWORDS = new string[] { "ORDER", "DESC", "TEXT", "GROUP", "ASC", "MIN", "MAX", "SUM", "DATE", "DATA", "DEC", "CASE", "CAST" };
public PFFormService(IRepository repository)
: base(repository)
{
}
/// <summary>
/// 获取实体语法
/// </summary>
/// <param name="dataBaseType"></param>
/// <param name="obj"></param>
/// <param name="list"></param>
/// <param name="dstOrgId"></param>
/// <param name="sqlType">获取语法类型 0-update 和insert 1-仅获取update 2-仅获取insert</param>
public void GetSqlByObject(DataBaseType dataBaseType, object obj, List<string> list, string dstOrgId, int sqlType)
{
this.DoGetSqlByEntity(dataBaseType, obj, list, dstOrgId, sqlType);
}
/// <summary>
/// 创建表单设置版本信息
/// </summary>
/// <param name="configEnum">当前设置类型</param>
/// <param name="ids">ID列表 逗号隔开</param>
public void CreateFormConfigVersion(PFFormConfigVersionEnum configEnum, string ids)
{
//List<Guid> arrays = string.IsNullOrEmpty(ids) ? null : ids.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries).Select(t => new Guid(t)).ToList();
//if (arrays == null || !arrays.Any()) return;
//Guid? orgId = null;
//List<string> cookies = new List<string>();
//switch (configEnum)
//{
// case PFFormConfigVersionEnum.Form:
// var forms = this.GetEntities<T_PF_FORM>(t => arrays.Contains(t.ID), new BaseFilter()).ToList();
// foreach (var form in forms)
// {
// orgId = form.ORG_ID;
// cookies.Add(string.Format("form_config_form_{0}_{1}", form.CODE, form.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.Btn:
// var btns = this.GetEntities<T_PF_BTN>(t => arrays.Contains(t.ID), new BaseFilter()).ToList();
// foreach (var btn in btns)
// {
// orgId = btn.ORG_ID;
// if (btn.PAGE_CUSTOM_FORM_ID != null)
// {
// var form = this.GetEntity<T_PF_FORM>(btn.PAGE_CUSTOM_FORM_ID.ToString());
// if (form != null)
// cookies.Add(string.Format("form_config_custom_{0}_{1}", form.CODE, btn.ORG_ID));
// }
// else if (btn.PAGE_TABLE_ID != null)
// {
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", btn.PAGE_TABLE_ID, btn.ORG_ID));
// }
// else if (btn.PAGE_EDIT_ID != null)
// {
// var pageEdit = this.GetEntity<T_PF_PAGE_EDIT>(btn.PAGE_EDIT_ID.ToString(), new string[] { "Nav_PageForm" });
// if (pageEdit != null)
// {
// if (pageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}", pageEdit.Nav_PageForm.CODE, pageEdit.ORG_ID));
// }
// else
// {
// var pageTree = this.GetEntity<T_PF_PAGE_TREE>(btn.PAGE_EDIT_ID.ToString(), new string[] { "Nav_PageForm" });
// if (pageTree.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_tree_{0}_{1}", pageTree.Nav_PageForm.CODE, pageTree.ORG_ID));
// }
// }
// }
// break;
// case PFFormConfigVersionEnum.Column:
// var columns = this.GetEntities<T_PF_COLUMN>(t => arrays.Contains(t.ID), new BaseFilter()).ToList();
// foreach (var column in columns)
// {
// orgId = column.ORG_ID;
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", column.PAGE_TABLE_ID, column.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.EditColumn:
// var editColumns = this.GetEntities<T_PF_EDIT_COLUMN>(t => arrays.Contains(t.ID), new BaseFilter(), new string[] { "Nav_PageEdit.Nav_PageForm" }).ToList();
// foreach (var editColumn in editColumns)
// {
// orgId = editColumn.ORG_ID;
// if (editColumn.Nav_PageEdit != null && editColumn.Nav_PageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}", editColumn.Nav_PageEdit.Nav_PageForm.CODE, editColumn.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.EditColumnFillMap:
// var editColumnFillMaps = this.GetEntities<T_PF_EDIT_COLUMN_FILL_MAP>(t => arrays.Contains(t.ID), new BaseFilter(),
// new string[] { "Nav_EditColumn.Nav_PageEdit.Nav_PageForm" }).ToList();
// foreach (var editColumnFillMap in editColumnFillMaps)
// {
// orgId = editColumnFillMap.ORG_ID;
// if (editColumnFillMap.Nav_EditColumn != null && editColumnFillMap.Nav_EditColumn.Nav_PageEdit != null
// && editColumnFillMap.Nav_EditColumn.Nav_PageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}",
// editColumnFillMap.Nav_EditColumn.Nav_PageEdit.Nav_PageForm.CODE, editColumnFillMap.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.EditColumnFillMapDetail:
// var editColumnFillMapDetails = this.GetEntities<T_PF_EDIT_COLUMN_FILL_MAP_D>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit.Nav_PageForm" }).ToList();
// foreach (var editColumnFillMapDetail in editColumnFillMapDetails)
// {
// orgId = editColumnFillMapDetail.ORG_ID;
// if (editColumnFillMapDetail.Nav_EditColumnFillMap != null && editColumnFillMapDetail.Nav_EditColumnFillMap.Nav_EditColumn != null
// && editColumnFillMapDetail.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit != null
// && editColumnFillMapDetail.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}",
// editColumnFillMapDetail.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit.Nav_PageForm.CODE,
// editColumnFillMapDetail.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.EditColumnFilter:
// var editColumnFilters = this.GetEntities<T_PF_EDIT_COLUMN_FILTER>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_EditColumn.Nav_PageEdit.Nav_PageForm" }).ToList();
// foreach (var editColumnFilter in editColumnFilters)
// {
// orgId = editColumnFilter.ORG_ID;
// if (editColumnFilter.Nav_EditColumn != null && editColumnFilter.Nav_EditColumn.Nav_PageEdit != null
// && editColumnFilter.Nav_EditColumn.Nav_PageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}",
// editColumnFilter.Nav_EditColumn.Nav_PageEdit.Nav_PageForm.CODE, editColumnFilter.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageCustom:
// var pageCustoms = this.GetEntities<T_PF_PAGE_CUSTOM>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var pageCustom in pageCustoms)
// {
// orgId = pageCustom.ORG_ID;
// if (pageCustom.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_custom_{0}_{1}", pageCustom.Nav_PageForm.CODE, pageCustom.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageEdit:
// var pageEdits = this.GetEntities<T_PF_PAGE_EDIT>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var pageEdit in pageEdits)
// {
// orgId = pageEdit.ORG_ID;
// if (pageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}", pageEdit.Nav_PageForm.CODE, pageEdit.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageTable:
// var pageTables = this.GetEntities<T_PF_PAGE_TABLE>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var pageTable in pageTables)
// {
// orgId = pageTable.ORG_ID;
// if (pageTable.Nav_PageForm != null)
// {
// cookies.Add(string.Format("form_config_table_{0}_{1}_{2}", pageTable.Nav_PageForm.CODE, pageTable.ORG_ID, (pageTable.PARENT_ID == null ? "" : pageTable.PARENT_ID.ToString())));
// cookies.Add(string.Format("form_config_table_{0}_{1}_{2}_{3}", pageTable.Nav_PageForm.CODE, pageTable.ORG_ID, (pageTable.PARENT_ID == null ? "" : pageTable.PARENT_ID.ToString()),
// pageTable.ID));
// }
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", pageTable.ID, pageTable.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageTree:
// var pageTrees = this.GetEntities<T_PF_PAGE_TREE>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var pageTree in pageTrees)
// {
// orgId = pageTree.ORG_ID;
// if (pageTree.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_tree_{0}_{1}", pageTree.Nav_PageForm.CODE, pageTree.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.Query:
// var querys = this.GetEntities<T_PF_QUERY>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var query in querys)
// {
// orgId = query.ORG_ID;
// cookies.Add(string.Format("form_config_search_{0}_{1}", query.PAGE_FORM_ID, query.ORG_ID));
// if (query.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_search_{0}_{1}", query.Nav_PageForm.CODE, query.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.TableParams:
// var tableParams = this.GetEntities<T_PF_TABLE_PARAMS>(t => arrays.Contains(t.ID), new BaseFilter()).ToList();
// foreach (var tableParam in tableParams)
// {
// orgId = tableParam.ORG_ID;
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", tableParam.PAGE_TABLE_ID, tableParam.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.TreeColumn:
// var treeColumns = this.GetEntities<T_PF_TREE_COLUMN>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageTree.Nav_PageForm" }).ToList();
// foreach (var treeColumn in treeColumns)
// {
// orgId = treeColumn.ORG_ID;
// if (treeColumn.Nav_PageTree != null && treeColumn.Nav_PageTree.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_tree_{0}_{1}", treeColumn.Nav_PageTree.Nav_PageForm.CODE, treeColumn.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageEditPanel:
// var pageEditPanels = this.GetEntities<T_PF_PAGE_EDIT_PANEL>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageEdit.Nav_PageForm" }).ToList();
// foreach (var pageEditPanel in pageEditPanels)
// {
// orgId = pageEditPanel.ORG_ID;
// if (pageEditPanel.Nav_PageEdit != null && pageEditPanel.Nav_PageEdit.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_edit_{0}_{1}", pageEditPanel.Nav_PageEdit.Nav_PageForm.CODE, pageEditPanel.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageChart:
// var pageCharts = this.GetEntities<T_PF_PAGE_CHART>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var pageChart in pageCharts)
// {
// orgId = pageChart.ORG_ID;
// if (pageChart.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_chart_{0}_{1}", pageChart.Nav_PageForm.CODE, pageChart.ORG_ID));
// cookies.Add(string.Format("form_config_chart_{0}_{1}", pageChart.PAGE_FORM_ID, pageChart.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageChartParam:
// var pageChartParams = this.GetEntities<T_PF_PAGE_CHART_PARAM>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageChart.Nav_PageForm" }).ToList();
// foreach (var pageChartParam in pageChartParams)
// {
// orgId = pageChartParam.ORG_ID;
// if (pageChartParam.Nav_PageChart != null && pageChartParam.Nav_PageChart.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_chart_{0}_{1}", pageChartParam.Nav_PageChart.Nav_PageForm.CODE, pageChartParam.ORG_ID));
// cookies.Add(string.Format("form_config_chart_{0}_{1}", pageChartParam.Nav_PageChart.PAGE_FORM_ID, pageChartParam.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.ColumnFilter:
// var columnFilters = this.GetEntities<T_PF_COLUMN_FILTER>(t => arrays.Contains(t.ID), new BaseFilter(), new string[] { "Nav_Column" }).ToList();
// foreach (var columnFilter in columnFilters)
// {
// orgId = columnFilter.ORG_ID;
// if (columnFilter.Nav_Column != null)
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", columnFilter.Nav_Column.PAGE_TABLE_ID, columnFilter.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.FormQuery:
// var formQuerys = this.GetEntities<T_PF_FORM_QUERY>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageForm" }).ToList();
// foreach (var formQuery in formQuerys)
// {
// orgId = formQuery.ORG_ID;
// cookies.Add(string.Format("form_config_search_{0}_{1}", formQuery.PAGE_FORM_ID, formQuery.ORG_ID));
// if (formQuery.Nav_PageForm != null)
// cookies.Add(string.Format("form_config_search_{0}_{1}", formQuery.Nav_PageForm.CODE, formQuery.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.PageTablePanel:
// var pageTabePanels = this.GetEntities<T_PF_PAGE_TABLE_PANEL>(t => arrays.Contains(t.ID),
// new BaseFilter(), new string[] { "Nav_PageTable.Nav_PageForm" }).ToList();
// foreach (var pageTablePanel in pageTabePanels)
// {
// orgId = pageTablePanel.ORG_ID;
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", pageTablePanel.PAGE_TABLE_ID, pageTablePanel.ORG_ID));
// }
// break;
// case PFFormConfigVersionEnum.ParamItem:
// var schemeIds = this.GetEntities<T_PF_PARAM_SCHEME_DETAIL>(t => arrays.Contains(t.PARAM_ITEM_ID), new BaseFilter()).Select(t => t.PARAM_SCHEME_ID).ToList();
// if (schemeIds.Any())
// this.CreateFormConfigVersion(PFFormConfigVersionEnum.ParamScheme, string.Join(",", schemeIds));
// break;
// case PFFormConfigVersionEnum.ParamScheme:
// var tempPageTableIds = this.GetEntities<T_PF_PAGE_TABLE>(t => arrays.Contains(t.PARAM_SCHEME_ID ?? Guid.Empty), new BaseFilter()).Select(t => t.ID).ToList();
// var tempPageEditIds = this.GetEntities<T_PF_PAGE_EDIT>(t => arrays.Contains(t.PARAM_SCHEME_ID ?? Guid.Empty), new BaseFilter()).Select(t => t.ID).ToList();
// if (tempPageTableIds.Any())
// this.CreateFormConfigVersion(PFFormConfigVersionEnum.PageTable, string.Join(",", tempPageTableIds));
// if (tempPageEditIds.Any())
// this.CreateFormConfigVersion(PFFormConfigVersionEnum.PageEdit, string.Join(",", tempPageEditIds));
// break;
//}
//if (orgId != null && cookies.Count > 0)
//{
// decimal version = decimal.Zero;
// BaseFilter filter = new BaseFilter();
// filter.OrgId = orgId;
// filter.Order = DbOrder.DESC;
// filter.Sort = "VERSION";
// filter.OrgType = FilterOrgTypeEnum.仅本组织;
// var lastMaxVersion = this.GetOrderEntities<T_PF_FORM_CONFIG_VERSION>(null, filter).FirstOrDefault();
// if (lastMaxVersion != null)
// version = lastMaxVersion.VERSION;
// version += 1;
// List<T_PF_FORM_CONFIG_VERSION_D> details = new List<T_PF_FORM_CONFIG_VERSION_D>();
// T_PF_FORM_CONFIG_VERSION formConfigVersion = new T_PF_FORM_CONFIG_VERSION();
// formConfigVersion.ORG_ID = orgId;
// formConfigVersion.VERSION = version;
// foreach (var item in cookies)
// {
// T_PF_FORM_CONFIG_VERSION_D formConfigVersionDetail = new T_PF_FORM_CONFIG_VERSION_D();
// formConfigVersionDetail.ORG_ID = orgId;
// formConfigVersionDetail.REMOVE_COOKIE_KEY = item;
// formConfigVersionDetail.FORM_CONFIG_VERSION_ID = formConfigVersion.ID;
// details.Add(formConfigVersionDetail);
// }
// this.AddEntity(formConfigVersion);
// this.BantchAddEntity(details);
//}
}
/// <summary>
/// 依据表单编号获取更新表单配置语法
/// </summary>
/// <param name="orgId"></param>
/// <param name="formCodes"></param>
/// <param name="dstOrgId"></param>
/// <param name="dstFormConfigVersion"></param>
/// <param name="dstDataBaseType"></param>
/// <param name="sqlType"></param>
/// <param name="startTime">开始时间 从此时间之后的有异动的配置信息都会获取到</param>
/// <returns></returns>
public List<string> GetSqlsByFormCode(Guid orgId, List<string> formCodes, string dstOrgId, decimal dstFormConfigVersion, DataBaseType dstDataBaseType, int sqlType, DateTime? startTime, bool isInitOrg)
{
var forms = this.GetEntities<T_PF_FORM>(t => formCodes.Contains(t.CODE), new BaseFilter(orgId, FilterOrgTypeEnum.)).ToList();
return GetSqlsByFormId(orgId, forms.Select(t => t.ID).ToList(), dstOrgId, dstFormConfigVersion, dstDataBaseType, sqlType, startTime, isInitOrg, 1);
}
/// <summary>
/// 依据表单ID获取更新表单配置语法
/// </summary>
/// <param name="orgId"></param>
/// <param name="formIds"></param>
/// <param name="dstOrgId"></param>
/// <param name="dstFormConfigVersion"></param>
/// <param name="dstDataBaseType"></param>
/// <param name="sqlType"></param>
/// <param name="startTime">开始时间 从此时间之后的有异动的配置信息都会获取到</param>
/// <returns></returns>
public List<string> GetSqlsByFormId(Guid orgId, List<Guid> formIds, string dstOrgId, decimal dstFormConfigVersion, DataBaseType dstDataBaseType, int sqlType, DateTime? startTime, bool isInitOrg, int formType)
{
var filiterThisDep = new BaseFilter(orgId, FilterOrgTypeEnum.);
filiterThisDep.IgnoreDataRule = true;
#region SQL
if (formType == 2)
{
return GetSqlsByFormType(orgId, formIds, dstOrgId, dstFormConfigVersion, dstDataBaseType, sqlType, startTime, isInitOrg, formType);
}
#endregion
#region SQL
else if (formType == 3)
{
return GetSqlsByFormType(orgId, formIds, dstOrgId, dstFormConfigVersion, dstDataBaseType, sqlType, startTime, isInitOrg, formType);
}
#endregion
#region SQL
else
{
string dstOrgIdGuidStr = dstOrgId;
if (dstDataBaseType == DataBaseType.Oracle && !string.IsNullOrEmpty(dstOrgId))
dstOrgIdGuidStr = Utility.DataHelper.OracleToDotNet(dstOrgId);
if (string.IsNullOrEmpty(dstOrgIdGuidStr))
dstOrgIdGuidStr = orgId.ToString();
bool isCheckParent = formIds != null && formIds.Any();
List<string> cookies = new List<string>();
List<string> result = new List<string>();
List<Guid> tempFormIds = new List<Guid>();
var paramStartTime = DateTime.Now.AddDays(-7);
if (startTime != null)
paramStartTime = startTime.Value;
#region
Expression<Func<T_PF_PARAM_ITEM, bool>> paramItemExpression = t => isInitOrg || t.CREATE_TIME > paramStartTime
|| t.MODIFY_TIME > paramStartTime;
if (startTime != null)
paramItemExpression = paramItemExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var paramItems = this.GetEntities<T_PF_PARAM_ITEM>(paramItemExpression, filiterThisDep).ToList();
paramItems.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
});
Expression<Func<T_PF_PARAM_SCHEME, bool>> paramSchemeExpression = t => isInitOrg || t.CREATE_TIME > paramStartTime
|| t.MODIFY_TIME > paramStartTime;
if (startTime != null)
paramSchemeExpression = paramSchemeExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var paramSchemes = this.GetEntities<T_PF_PARAM_SCHEME>(paramSchemeExpression, filiterThisDep).ToList();
paramSchemes.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
});
Expression<Func<T_PF_PARAM_SCHEME_DETAIL, bool>> paramSchemeDetailExpression = t => isInitOrg || t.CREATE_TIME > paramStartTime
|| t.MODIFY_TIME > paramStartTime;
if (startTime != null)
paramSchemeDetailExpression = paramSchemeDetailExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var paramDetails = this.GetEntities<T_PF_PARAM_SCHEME_DETAIL>(paramSchemeDetailExpression, filiterThisDep).ToList();
paramDetails.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
});
List<Guid> itemIds = paramItems.Select(t => t.ID).ToList();
List<Guid> schemeIds = paramSchemes.Select(t => t.ID).ToList();
List<Guid> schemeDetailIds = paramDetails.Select(t => t.ID).ToList();
var allParamSchemeIds = this.GetEntities<T_PF_PARAM_SCHEME>(t => schemeIds.Contains(t.ID) ||
t.Nav_Details.Any(t1 => schemeDetailIds.Contains(t1.ID)) ||
t.Nav_Details.Any(t1 => itemIds.Contains(t1.PARAM_ITEM_ID)), new BaseFilter(orgId)).Select(t => t.ID).ToList();
if (allParamSchemeIds.Any())
{
var temppageTables = this.GetEntities<T_PF_PAGE_TABLE>(t => allParamSchemeIds.Contains(t.PARAM_SCHEME_ID ?? Guid.Empty), new BaseFilter(orgId)).ToList();
temppageTables.ForEach(t =>
{
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
cookies.Add(string.Format("form_config_tablebase_{0}_{1}", t.ID, dstOrgIdGuidStr));
if (t.Nav_PageForm != null)
{
cookies.Add(string.Format("form_config_table_{0}_{1}_{2}", t.Nav_PageForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString())));
cookies.Add(string.Format("form_config_table_{0}_{1}_{2}_{3}", t.Nav_PageForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString()),
t.ID));
}
});
var temppageEdits = this.GetEntities<T_PF_PAGE_EDIT>(t => allParamSchemeIds.Contains(t.PARAM_SCHEME_ID ?? Guid.Empty), new BaseFilter(orgId)).ToList();
temppageEdits.ForEach(t =>
{
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
}
#endregion
Expression<Func<T_PF_FORM, bool>> formExpression = t => isInitOrg || formIds.Contains(t.ID);
if (startTime != null)
formExpression = formExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var forms = this.GetEntities<T_PF_FORM>(formExpression, filiterThisDep).ToList();
forms.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
tempFormIds.Add(t.ID);
});
List<Guid> tmpFormIds = forms.Select(t => t.ID).ToList();
#region
Expression<Func<T_PF_PIC_FILTER, bool>> picExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID);
if (startTime != null)
picExpression = picExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pics = this.GetEntities<T_PF_PIC_FILTER>(picExpression, filiterThisDep).ToList();
pics.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID))
tempFormIds.Add(t.PAGE_FORM_ID);
});
List<Guid> picIds = pics.Select(t => t.ID).ToList();
Expression<Func<T_PF_PIC_FILTER_DETAIL, bool>> picDetailExpression = t => isInitOrg || isCheckParent && picIds.Contains(t.PIC_FILTER_ID);
if (startTime != null)
picDetailExpression = picDetailExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var picDetails = this.GetEntities<T_PF_PIC_FILTER_DETAIL>(picDetailExpression, filiterThisDep, new string[] { "Nav_PicFilter" }).ToList();
picDetails.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_PicFilter != null && t.Nav_PicFilter.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_PicFilter.PAGE_FORM_ID))
tempFormIds.Add(t.Nav_PicFilter.PAGE_FORM_ID);
});
#endregion
#region
Expression<Func<T_PF_FORM_RELATION, bool>> formRelationExpression = t => isInitOrg || tmpFormIds.Contains(t.PAGE_FORM_ID);
if (startTime != null)
formRelationExpression = formRelationExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var formRelations = this.GetEntities<T_PF_FORM_RELATION>(formRelationExpression, filiterThisDep).ToList();
formRelations.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID))
tempFormIds.Add(t.PAGE_FORM_ID);
});
#endregion
#region
Expression<Func<T_PF_PAGE_EDIT, bool>> editExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID ?? Guid.Empty);
if (startTime != null)
editExpression = editExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pageEdits = this.GetEntities<T_PF_PAGE_EDIT>(editExpression, filiterThisDep).ToList();
pageEdits.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
List<Guid> pageEditIds = pageEdits.Select(t => t.ID).ToList();
Expression<Func<T_PF_PAGE_EDIT_PANEL, bool>> editPanelExpression = t => isInitOrg || isCheckParent && pageEditIds.Contains(t.PAGE_EDIT_ID);
if (startTime != null)
editPanelExpression = editPanelExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var editPanels = this.GetEntities<T_PF_PAGE_EDIT_PANEL>(editPanelExpression, filiterThisDep, new string[] { "Nav_PageEdit" }).ToList();
editPanels.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_PageEdit != null && t.Nav_PageEdit.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_PageEdit.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_PageEdit.PAGE_FORM_ID.Value);
});
Expression<Func<T_PF_EDIT_COLUMN, bool>> editColumnExpression = t => isInitOrg || isCheckParent && pageEditIds.Contains(t.PAGE_EDIT_ID);
if (startTime != null)
editColumnExpression = editColumnExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var editColumns = this.GetEntities<T_PF_EDIT_COLUMN>(editColumnExpression, filiterThisDep, new string[] { "Nav_PageEdit" }).ToList();
editColumns.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_PageEdit != null && t.Nav_PageEdit.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_PageEdit.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_PageEdit.PAGE_FORM_ID.Value);
});
List<Guid> editColumnIds = editColumns.Select(t => t.ID).ToList();
Expression<Func<T_PF_EDIT_COLUMN_FILTER, bool>> editColumnFilterExpression = t => isInitOrg || isCheckParent && editColumnIds.Contains(t.EDIT_COLUMN_ID);
if (startTime != null)
editColumnFilterExpression = editColumnFilterExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var editColumnFilters = this.GetEntities<T_PF_EDIT_COLUMN_FILTER>(editColumnFilterExpression, filiterThisDep, new string[] { "Nav_EditColumn.Nav_PageEdit" }).ToList();
editColumnFilters.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_EditColumn != null && t.Nav_EditColumn.Nav_PageEdit != null && t.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID.Value);
});
Expression<Func<T_PF_EDIT_COLUMN_FILL_MAP, bool>> editColumnFillMapExpression = t => isInitOrg || isCheckParent && editColumnIds.Contains(t.EDIT_COLUMN_ID);
if (startTime != null)
editColumnFillMapExpression = editColumnFillMapExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var editColumnFillMaps = this.GetEntities<T_PF_EDIT_COLUMN_FILL_MAP>(editColumnFillMapExpression, filiterThisDep, new string[] { "Nav_EditColumn.Nav_PageEdit" }).ToList();
editColumnFillMaps.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_EditColumn != null && t.Nav_EditColumn.Nav_PageEdit != null && t.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID.Value);
});
var editColumnFillMapIds = editColumnFillMaps.Select(t => t.ID).ToList();
Expression<Func<T_PF_EDIT_COLUMN_FILL_MAP_D, bool>> editColumnFillMapDExpression = t => isInitOrg || isCheckParent && editColumnFillMapIds.Contains(t.EDIT_COLUMN_FILL_MAP_ID);
if (startTime != null)
editColumnFillMapDExpression = editColumnFillMapDExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var editColumnFillMapDetails = this.GetEntities<T_PF_EDIT_COLUMN_FILL_MAP_D>(editColumnFillMapDExpression, filiterThisDep, new string[] { "Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit" }).ToList();
editColumnFillMapDetails.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_EditColumnFillMap != null && t.Nav_EditColumnFillMap.Nav_EditColumn != null && t.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit != null
&& t.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_EditColumnFillMap.Nav_EditColumn.Nav_PageEdit.PAGE_FORM_ID.Value);
});
#endregion
#region
Expression<Func<T_PF_PAGE_CUSTOM, bool>> customExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID ?? Guid.Empty);
if (startTime != null)
customExpression = customExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pageCustoms = this.GetEntities<T_PF_PAGE_CUSTOM>(customExpression, filiterThisDep).ToList();
pageCustoms.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
#endregion
#region
Expression<Func<T_PF_PAGE_CHART, bool>> chartExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID ?? Guid.Empty);
if (startTime != null)
chartExpression = chartExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pageCharts = this.GetEntities<T_PF_PAGE_CHART>(chartExpression, filiterThisDep).ToList();
pageCharts.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
List<Guid> pageChartIds = pageCharts.Select(t => t.ID).ToList();
Expression<Func<T_PF_PAGE_CHART_PARAM, bool>> chartParamExpression = t => isInitOrg || isCheckParent && pageChartIds.Contains(t.PAGE_CHART_ID);
if (startTime != null)
chartParamExpression = chartParamExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pageChartParams = this.GetEntities<T_PF_PAGE_CHART_PARAM>(chartParamExpression, filiterThisDep, new string[] { "Nav_PageChart" }).ToList();
pageChartParams.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_PageChart != null && t.Nav_PageChart.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_PageChart.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_PageChart.PAGE_FORM_ID.Value);
});
#endregion
#region
Expression<Func<T_PF_PAGE_TABLE, bool>> tableExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID ?? Guid.Empty);
if (startTime != null)
tableExpression = tableExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pageTables = this.GetEntities<T_PF_PAGE_TABLE>(tableExpression, filiterThisDep, new string[] { "Nav_PageForm" }).ToList();
pageTables.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
cookies.Add(string.Format("form_config_tablebase_{0}_{1}", t.ID, dstOrgIdGuidStr));
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
if (t.Nav_PageForm != null)
{
cookies.Add(string.Format("form_config_table_{0}_{1}_{2}", t.Nav_PageForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString())));
cookies.Add(string.Format("form_config_table_{0}_{1}_{2}_{3}", t.Nav_PageForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString()),
t.ID));
}
});
List<Guid> pageTableIds = pageTables.Select(t => t.ID).ToList();
Expression<Func<T_PF_PAGE_TABLE_PANEL, bool>> tablePanelExpression = t => isInitOrg || isCheckParent && pageTableIds.Contains(t.PAGE_TABLE_ID);
if (startTime != null)
tablePanelExpression = tablePanelExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var tablePanels = this.GetEntities<T_PF_PAGE_TABLE_PANEL>(tablePanelExpression, filiterThisDep).ToList();
tablePanels.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
cookies.Add(string.Format("form_config_tablebase_{0}_{1}", t.PAGE_TABLE_ID, t.ORG_ID));
});
Expression<Func<T_PF_COLUMN, bool>> columnExpression = t => isInitOrg || isCheckParent && pageTableIds.Contains(t.PAGE_TABLE_ID ?? Guid.Empty);
if (startTime != null)
columnExpression = columnExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var columns = this.GetEntities<T_PF_COLUMN>(columnExpression, filiterThisDep).ToList();
var columnIds = columns.Select(t => t.ID).ToList();
columns.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
cookies.Add(string.Format("form_config_tablebase_{0}_{1}", t.PAGE_TABLE_ID, t.ORG_ID));
});
Expression<Func<T_PF_COLUMN_FILTER, bool>> columnFilterExpression = t => isInitOrg || isCheckParent && columnIds.Contains(t.COLUMN_ID);
if (startTime != null)
columnFilterExpression = columnFilterExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var columnFilters = this.GetEntities<T_PF_COLUMN_FILTER>(columnFilterExpression, filiterThisDep, new string[] { "Nav_Column" }).ToList();
var tempTableIds = columns.Where(t => t.PAGE_TABLE_ID != null).Select(t => t.PAGE_TABLE_ID.Value).ToList();
columnFilters.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_Column != null && t.Nav_Column.PAGE_TABLE_ID != null && tempFormIds.Contains(t.Nav_Column.PAGE_TABLE_ID.Value))
tempTableIds.Add(t.Nav_Column.PAGE_TABLE_ID.Value);
});
if (tempTableIds.Any())
{
var tempPageTables = this.GetEntities<T_PF_PAGE_TABLE>(t => tempTableIds.Contains(t.ID), filiterThisDep, new string[] { "Nav_PageForm" }).ToList();
tempPageTables.ForEach(t =>
{
if (t.Nav_PageForm != null)
{
cookies.Add(string.Format("form_config_table_{0}_{1}_{2}", t.Nav_PageForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString())));
cookies.Add(string.Format("form_config_table_{0}_{1}_{2}_{3}", t.Nav_PageForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString()),
t.ID));
}
});
var tempColFormIds = tempPageTables.Where(t => t.PAGE_FORM_ID != null).Select(t => t.PAGE_FORM_ID.Value).ToList();
tempColFormIds.ForEach(t =>
{
if (!tempFormIds.Contains(t))
tempFormIds.Add(t);
});
}
Expression<Func<T_PF_TABLE_PARAMS, bool>> tableParamsExpression = t => isInitOrg || isCheckParent && pageTableIds.Contains(t.PAGE_TABLE_ID);
if (startTime != null)
tableParamsExpression = tableParamsExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var tableParams = this.GetEntities<T_PF_TABLE_PARAMS>(tableParamsExpression, filiterThisDep, new string[] { "Nav_PageTable" }).ToList();
tableParams.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_PageTable != null && t.Nav_PageTable.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_PageTable.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_PageTable.PAGE_FORM_ID.Value);
});
#endregion
#region
Expression<Func<T_PF_FORM_QUERY, bool>> formQueryExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID ?? Guid.Empty);
if (startTime != null)
formQueryExpression = formQueryExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var formQuerys = this.GetEntities<T_PF_FORM_QUERY>(formQueryExpression, filiterThisDep, new string[] { "Nav_PageForm" }).ToList();
formQuerys.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
var formQueryIds = formQuerys.Select(t => t.ID).ToList();
Expression<Func<T_PF_QUERY, bool>> queryExpression = t => isInitOrg || isCheckParent && formQueryIds.Contains(t.PAGE_FORM_QUERY_ID ?? Guid.Empty);
if (startTime != null)
queryExpression = queryExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var querys = this.GetEntities<T_PF_QUERY>(queryExpression, filiterThisDep).ToList();
querys.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
#endregion
#region
Expression<Func<T_PF_PAGE_TREE, bool>> treeExpression = t => isInitOrg || isCheckParent && tmpFormIds.Contains(t.PAGE_FORM_ID ?? Guid.Empty);
if (startTime != null)
treeExpression = treeExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var pageTrees = this.GetEntities<T_PF_PAGE_TREE>(treeExpression, filiterThisDep).ToList();
pageTrees.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.PAGE_FORM_ID != null && !tempFormIds.Contains(t.PAGE_FORM_ID.Value))
tempFormIds.Add(t.PAGE_FORM_ID.Value);
});
List<Guid> pageTreeIds = pageTrees.Select(t => t.ID).ToList();
Expression<Func<T_PF_TREE_COLUMN, bool>> treeColumnExpression = t => isInitOrg || isCheckParent && pageTreeIds.Contains(t.PAGE_TREE_ID);
if (startTime != null)
treeColumnExpression = treeColumnExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var treeColumns = this.GetEntities<T_PF_TREE_COLUMN>(treeColumnExpression, filiterThisDep, new string[] { "Nav_PageTree" }).ToList();
treeColumns.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
if (t.Nav_PageTree != null && t.Nav_PageTree.PAGE_FORM_ID != null && !tempFormIds.Contains(t.Nav_PageTree.PAGE_FORM_ID.Value))
tempFormIds.Add(t.Nav_PageTree.PAGE_FORM_ID.Value);
});
#endregion
#region
Expression<Func<T_PF_BTN, bool>> btnExpression = t => isInitOrg || isCheckParent && (tmpFormIds.Contains(t.PAGE_CUSTOM_FORM_ID ?? Guid.Empty) || pageTableIds.Contains(t.PAGE_TABLE_ID ?? Guid.Empty)
|| pageTreeIds.Contains(t.PAGE_EDIT_ID ?? Guid.Empty) || pageEditIds.Contains(t.PAGE_EDIT_ID ?? Guid.Empty));
if (startTime != null)
btnExpression = btnExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var btns = this.GetEntities<T_PF_BTN>(btnExpression, filiterThisDep).ToList();
btns.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
});
var tempBtnFormIds = btns.Where(t => t.PAGE_CUSTOM_FORM_ID != null).Select(t => t.PAGE_CUSTOM_FORM_ID.Value).ToList();
var tempBtnTableIds = btns.Where(t => t.PAGE_TABLE_ID != null).Select(t => t.PAGE_TABLE_ID.Value).ToList();
var tempBtnEditIds = btns.Where(t => t.PAGE_EDIT_ID != null).Select(t => t.PAGE_EDIT_ID.Value).ToList();
if (tempBtnTableIds.Any())
{
var tempPageTables = this.GetEntities<T_PF_PAGE_TABLE>(t => tempBtnTableIds.Contains(t.ID), filiterThisDep).ToList();
var tempTableFormIds = tempPageTables.Where(t => t.PAGE_FORM_ID != null).Select(t => t.PAGE_FORM_ID.Value).ToList();
tempTableFormIds.ForEach(t =>
{
if (!tempBtnFormIds.Contains(t))
tempBtnFormIds.Add(t);
});
}
if (tempBtnEditIds.Any())
{
var tempPageTrees = this.GetEntities<T_PF_PAGE_TREE>(t => tempBtnEditIds.Contains(t.ID), filiterThisDep).ToList();
var tempTreeFormIds = tempPageTrees.Where(t => t.PAGE_FORM_ID != null).Select(t => t.PAGE_FORM_ID.Value).ToList();
tempTreeFormIds.ForEach(t =>
{
if (!tempBtnFormIds.Contains(t))
tempBtnFormIds.Add(t);
});
var tempPageEdits = this.GetEntities<T_PF_PAGE_EDIT>(t => tempBtnEditIds.Contains(t.ID), filiterThisDep).ToList();
var tempEditFormIds = tempPageEdits.Where(t => t.PAGE_FORM_ID != null).Select(t => t.PAGE_FORM_ID.Value).ToList();
tempEditFormIds.ForEach(t =>
{
if (!tempBtnFormIds.Contains(t))
tempBtnFormIds.Add(t);
});
}
tempBtnFormIds.ForEach(t =>
{
if (!tempFormIds.Contains(t))
tempFormIds.Add(t);
});
#endregion
#region
if (dstFormConfigVersion > decimal.Zero && tempFormIds.Any())
{
var versionForms = this.GetEntities<T_PF_FORM>(t => tempFormIds.Contains(t.ID), new BaseFilter(orgId)).ToList();
versionForms.ForEach(t =>
{
cookies.Add(string.Format("form_config_form_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_custom_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_edit_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_tree_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_table_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_search_{0}_{1}", t.ID, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_search_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_chart_{0}_{1}", t.CODE, dstOrgIdGuidStr));
cookies.Add(string.Format("form_config_chart_{0}_{1}", t.ID, dstOrgIdGuidStr));
});
dstFormConfigVersion++;
T_PF_FORM_CONFIG_VERSION formConfigVersion = new T_PF_FORM_CONFIG_VERSION();
formConfigVersion.VERSION = dstFormConfigVersion;
DoGetSqlByEntity(dstDataBaseType, formConfigVersion, result, dstOrgId, sqlType);
foreach (var item in cookies)
{
T_PF_FORM_CONFIG_VERSION_D formConfigVersionDetail = new T_PF_FORM_CONFIG_VERSION_D();
formConfigVersionDetail.REMOVE_COOKIE_KEY = item;
formConfigVersionDetail.FORM_CONFIG_VERSION_ID = formConfigVersion.ID;
DoGetSqlByEntity(dstDataBaseType, formConfigVersionDetail, result, dstOrgId, sqlType);
}
}
#endregion
return result;
}
#endregion
}
/// <summary>
/// 生成菜单/跑批SQL
/// </summary>
/// <param name="orgId"></param>
/// <param name="formIds"></param>
/// <param name="dstOrgId"></param>
/// <param name="dstFormConfigVersion"></param>
/// <param name="dstDataBaseType"></param>
/// <param name="sqlType"></param>
/// <param name="startTime"></param>
/// <param name="isInitOrg"></param>
/// <param name="formType"></param>
/// <returns></returns>
public List<string> GetSqlsByFormType(Guid orgId, List<Guid> formIds, string dstOrgId, decimal dstFormConfigVersion, DataBaseType dstDataBaseType, int sqlType, DateTime? startTime, bool isInitOrg, int formType)
{
List<string> result = new List<string>();
string dstOrgIdGuidStr = dstOrgId;
if (dstDataBaseType == DataBaseType.Oracle && !string.IsNullOrEmpty(dstOrgId))
dstOrgIdGuidStr = Utility.DataHelper.OracleToDotNet(dstOrgId);
if (string.IsNullOrEmpty(dstOrgIdGuidStr))
dstOrgIdGuidStr = orgId.ToString();
bool isCheckParent = formIds != null && formIds.Any();//是否勾选数据
var filiterThisDep = new BaseFilter(orgId, FilterOrgTypeEnum.);
filiterThisDep.IgnoreDataRule = true;
if (formType == 2)//菜单
{
Expression<Func<T_PF_MENU, bool>> editExpression = t => isInitOrg || formIds.Contains((Guid)t.MENU_FORM_ID);
if (startTime != null)
editExpression = editExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var menus = this.GetEntities<T_PF_MENU>(editExpression, filiterThisDep).OrderBy(x => x.MODIFY_TIME).ToList();
List<T_PF_MENU> orderMenus = new List<T_PF_MENU>();
foreach (var menu in menus)
{
GetOrderMenus(menu, menus, orderMenus);
}
orderMenus.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
});
}
else//跑批
{
Expression<Func<T_FM_SYNC_TASK, bool>> editExpression = t => isInitOrg;
if (startTime != null)
editExpression = editExpression.Or(t => t.CREATE_TIME > startTime || t.MODIFY_TIME > startTime);
var tasks = this.GetEntities<T_FM_SYNC_TASK>(editExpression, filiterThisDep).OrderBy(x => x.CREATE_TIME).ToList();
tasks.ForEach(t =>
{
DoGetSqlByEntity(dstDataBaseType, t, result, dstOrgId, sqlType);
});
}
return result;
}
private void GetOrderMenus(T_PF_MENU currentMenu, List<T_PF_MENU> menus, List<T_PF_MENU> orderMenus)
{
var parentId = currentMenu.PARENT_ID;
if (parentId != null && menus.Where(x => x.ID == parentId) != null && menus.Where(x => x.ID == parentId).Any())
{
GetOrderMenus(menus.FirstOrDefault(x => x.ID == parentId), menus, orderMenus);
if (!orderMenus.Where(x => x.ID == currentMenu.ID).Any())
{
orderMenus.Add(currentMenu);
}
}
else
{
if (!orderMenus.Where(x => x.ID == currentMenu.ID).Any())
{
orderMenus.Add(currentMenu);
}
}
}
/// <summary>
/// 获取实体表语法
/// </summary>
/// <param name="orgId"></param>
/// <param name="dataBaseType"></param>
/// <param name="entityNames"></param>
/// <param name="dstOrgId"></param>
/// <returns></returns>
public List<string> GetSqlByEntity(DataBaseType dataBaseType, Guid orgId, string entityNames, string dstOrgId, int sqlType)
{
var temps = entityNames.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList();
if (!temps.Any()) return null;
List<string> list = new List<string>();
foreach (var item in temps)
{
Type type = DataHelper.GetTypeByEntityName(item);
MethodInfo methodInfo = this.GetType().GetMethod("GetEntitisSql", BindingFlags.Instance | BindingFlags.Public | BindingFlags.Static);
methodInfo.MakeGenericMethod(new Type[] { type }).
Invoke(this, new object[] { dataBaseType, orgId, list, dstOrgId, sqlType });
}
return list;
}
/// <summary>
///根据来源组织初始化目的组织 配置数据
/// </summary>
/// <param name="srcOrgCode">来源组织编号</param>
/// <param name="destOrgCode">目的组织编号</param>
/// <param name="destOrgName">目的组织名称</param>
public void InitOrgBySrcOrg(string srcOrgCode, string destOrgCode, string destOrgName)
{
if (string.IsNullOrEmpty(destOrgCode))
throw new Exception("目标组织编号不允许为空");
if (string.IsNullOrEmpty(destOrgName))
throw new Exception("目标组织名称不允许为空");
var srcOrg = this.GetEntity<T_FM_ORGANIZATION>(t => t.CODE == srcOrgCode);
if (srcOrg == null)
throw new Exception("来源组织不存在,请确认");
var destOrg = this.GetEntity<T_FM_ORGANIZATION>(t => t.CODE == destOrgCode);
if (destOrg != null)
throw new Exception("已存在编号" + destOrgCode + "的组织,不允许执行此操作");
destOrg = new T_FM_ORGANIZATION();
destOrg.CODE = destOrgCode;
destOrg.NAME = destOrgName;
this.AddEntity(destOrg);
List<Guid> destOrgIds = new List<Guid>();
destOrgIds.Add(destOrg.ID);
this.InitOrgByOrg(srcOrg.ID, destOrgIds, null);
}
/// <summary>
/// 初始化组织
/// </summary>
/// <param name="srcOrgId"></param>
/// <param name="destOrgIds"></param>
/// <param name="startTime"></param>
public void InitOrgByOrg(Guid srcOrgId, List<Guid> destOrgIds, DateTime? startTime)
{
List<Guid> destInitOrgIds = new List<Guid>();
List<Guid> destSynchOrgIds = new List<Guid>();
var destOrgs = this.GetEntities<T_FM_ORGANIZATION>(t => destOrgIds.Contains(t.ID), new BaseFilter()).ToList();
foreach (var destOrg in destOrgs)
{
var isExistForm = this.GetEntities<T_PF_FORM>(null, new BaseFilter(destOrg.ID)).Any();
if (isExistForm)
{
if (startTime == null)
throw new Exception("已进行初始化组织,开始时间不允许为空");
destSynchOrgIds.Add(destOrg.ID);
}
else
{
destInitOrgIds.Add(destOrg.ID);
}
}
if (destInitOrgIds.Any())
this.DoSynchFormConfigByOrg(srcOrgId, destInitOrgIds, null);
if (destSynchOrgIds.Any())
this.DoSynchFormConfigByOrg(srcOrgId, destSynchOrgIds, startTime);
}
/// <summary>
/// 同步表单配置信息
/// </summary>
/// <param name="srcOrgId"></param>
/// <param name="destOrgIds"></param>
/// <param name="startTime"></param>
public void SynchFormConfigByOrg(Guid srcOrgId, List<Guid> destOrgIds, DateTime? startTime)
{
this.DoSynchFormConfigByOrg(srcOrgId, destOrgIds, startTime);
}
/// <summary>
/// 执行语法并且获取执行结果
/// </summary>
/// <param name="sql"></param>
/// <returns></returns>
public ExecuteSqlResult ExcuteSqlAndGetResult(string sql)
{
ExecuteSqlResult executeSqlResult = new ExecuteSqlResult();
if (string.IsNullOrEmpty(sql)) return executeSqlResult;
int tableIndex = 1;
var arr = sql.Split(new char[] { ';' }, StringSplitOptions.RemoveEmptyEntries).ToList();
foreach (var s in arr)
DoExcuteSqlAndGetResult(s, executeSqlResult, ref tableIndex);
foreach (var table in executeSqlResult.Tables)
{
if (!table.IsSelectTable) continue;
ExecuteSqlColumn column = new ExecuteSqlColumn()
{
FieldName = "RowNo",
Label = "序号"
};
table.Columns.Insert(0, column);
int rowIndex = 1;
foreach (var row in table.Rows)
{
ExecuteSqlRowColumn executeSqlRowColumn = new ExecuteSqlRowColumn()
{
ColumnId = column.ID,
Value = rowIndex.ToString()
};
row.Datas.Add(executeSqlRowColumn);
rowIndex++;
}
}
return executeSqlResult;
}
private void GetConfigBySrc<T>(List<T> srcEntities,
Guid destOrgId, Dictionary<Guid, Guid> entityRelations,
List<T> destAddEntities, List<T> destUpdateEntities, string relationFieldName, DateTime? startTime,
Action<T, T, Dictionary<Guid, Guid>> copyFieldAction,
Func<T, T> getEntityFunc,
Func<T, bool> vilFunc,
Action<T> handleNewEntityAction)
where T : EntityBase<Guid>, new()
{
if (srcEntities == null || !srcEntities.Any()) return;
srcEntities.ForEach(t =>
{
bool isAdd = false;
T destEntity = null;
if (getEntityFunc != null)
destEntity = getEntityFunc(t);
if (destEntity == null)
{
isAdd = true;
destEntity = new T();
}
entityRelations[t.ID] = destEntity.ID;
if (startTime != null)
{
if (t.CREATE_TIME < startTime || t.MODIFY_TIME < startTime)
return;
}
if (vilFunc != null)
{
bool isVil = vilFunc(t);
if (!isVil) return;
}
CopyUtils.CopyObject(destEntity, t, new string[] { "CREATER_ID", "MODIFIER_ID" });
destEntity.ORG_ID = destOrgId;
if (!string.IsNullOrEmpty(relationFieldName) && entityRelations != null)
{
Type srcType = t.GetType();
Type destType = destEntity.GetType();
var srcP = srcType.GetProperty(relationFieldName);
var destP = destType.GetProperty(relationFieldName);
if (srcP != null && srcP.PropertyType == destP.PropertyType)
{
var value = LibUtils.ToGuid(srcP.GetValue(t, null));
try
{
Guid destId;
if (value != null && entityRelations.TryGetValue(value.Value, out destId))
destP.SetValue(destEntity, destId, null);
}
catch
{ }
}
}
if (copyFieldAction != null)
copyFieldAction(t, destEntity, entityRelations);
if (isAdd)
destAddEntities.Add(destEntity);
else
destUpdateEntities.Add(destEntity);
if (handleNewEntityAction != null)
handleNewEntityAction(destEntity);
});
}
private void GetConfigBySrcOnTree<T>(List<T> srcEntities, Guid? srcParentId, Guid? destParentId,
Guid destOrgId, Dictionary<Guid, Guid> entityRelations,
List<T> destAddEntities, List<T> destUpdateEntities, string relationFieldName, DateTime? startTime,
Action<T, T, Dictionary<Guid, Guid>> copyFieldAction,
Func<T, Guid?, T> getEntityFunc,
Func<T, bool> vilFunc,
Action<T> handleNewEntityAction)
where T : MesTreeEntityBase, new()
{
if (srcEntities == null || !srcEntities.Any()) return;
var temps = srcEntities.Where(t => t.PARENT_ID == srcParentId).ToList();
if (!temps.Any()) return;
temps.ForEach(t =>
{
T destEntity = null;
if (getEntityFunc != null)
destEntity = getEntityFunc(t, destParentId);
bool isAdd = false;
if (destEntity == null)
{
destEntity = new T();
isAdd = true;
}
entityRelations[t.ID] = destEntity.ID;
bool isCopy = true;
if (startTime != null)
{
if (t.CREATE_TIME < startTime || t.MODIFY_TIME < startTime)
isCopy = false;
}
if (vilFunc != null)
{
bool isVil = vilFunc(t);
if (!isVil) isCopy = false;
}
if (isCopy)
{
CopyUtils.CopyObject(destEntity, t, new string[] { "CREATER_ID", "MODIFIER_ID" });
destEntity.ORG_ID = destOrgId;
if (!string.IsNullOrEmpty(relationFieldName) && entityRelations != null)
{
Type srcType = t.GetType();
Type destType = destEntity.GetType();
var srcP = srcType.GetProperty(relationFieldName);
var destP = destType.GetProperty(relationFieldName);
if (srcP != null && srcP.PropertyType == destP.PropertyType)
{
var value = LibUtils.ToGuid(srcP.GetValue(t, null));
try
{
Guid destId;
if (value != null && entityRelations.TryGetValue(value.Value, out destId))
destP.SetValue(destEntity, destId, null);
}
catch
{ }
}
}
copyFieldAction?.Invoke(t, destEntity, entityRelations);
if (destParentId != null && isAdd)
destEntity.PARENT_ID = destParentId;
if (isAdd)
destAddEntities.Add(destEntity);
else
destUpdateEntities.Add(destEntity);
handleNewEntityAction?.Invoke(destEntity);
}
GetConfigBySrcOnTree(srcEntities, t.ID, destEntity.ID, destOrgId,
entityRelations, destAddEntities, destUpdateEntities, relationFieldName, startTime, copyFieldAction,
getEntityFunc, vilFunc, handleNewEntityAction);
});
}
/// <summary>
///
/// </summary>
/// <param name="dataBaseType"></param>
/// <param name="obj"></param>
/// <param name="result"></param>
/// <param name="dstOrgId"></param>
/// <param name="sqlType">获取语法类型 0-update 和insert 1-仅获取update 2-仅获取insert</param>
private void DoGetSqlByEntity(DataBaseType dataBaseType, object obj, List<string> result, string dstOrgId, int sqlType)
{
Type objType = obj.GetType();
Dictionary<string, string> fields = new Dictionary<string, string>();
string MODIFY_TIME = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
foreach (var mi in objType.GetProperties())
{
if (string.Compare(mi.Name, "NAV_PROPERTY", true) != 0 && mi.Name.StartsWith("Nav_", StringComparison.OrdinalIgnoreCase) ||
mi.Name.StartsWith("VIR_", StringComparison.OrdinalIgnoreCase) ||
mi.Name.StartsWith("VIRTUAL_", StringComparison.OrdinalIgnoreCase) ||
mi.Name.ToUpper() != mi.Name)
{
if (mi.DeclaringType.Name == "T_PF_MENU" && mi.Name == "MineType")
{
if (dstOrgId=="A3DCE14A-13D9-D879-D9AB-821D4A3F1F93")
{
continue;//wyw 菜单导出 功能优化 SMS 没有 MineType
}
}
else
{
//wyw 菜单导出 功能优化
continue;
}
}
string fieldName = mi.Name;
string value = string.Empty;
if (string.Compare(mi.Name, "CREATER_ID", true) == 0 || string.Compare(mi.Name, "MODIFIER_ID", true) == 0)
value = "NULL";
else if (string.Compare(mi.Name, "MODIFY_TIME", true) == 0 || string.Compare(mi.Name, "MODIFY_TIME", true) == 0)//更新时间变成操作当天
value = MODIFY_TIME;
else if (string.Compare(mi.Name, "ORG_ID", true) == 0)
{
if (string.IsNullOrEmpty(dstOrgId))
{
var tmpObj = mi.GetValue(obj, null);
if (tmpObj != null)
{
value = tmpObj.ToString().ToUpper();
if (dataBaseType == DataBaseType.Oracle)
value = Utility.DataHelper.DotNetToOracle(value);
else if (dataBaseType == DataBaseType.MySQL || dataBaseType == DataBaseType.Postgresql)
value = tmpObj.ToString().ToLower();
}
}
else
value = dstOrgId;
}
else
{
string propertyTypeName = mi.PropertyType.Name;
string fullTypeName = mi.PropertyType.FullName;
if (string.Compare(propertyTypeName, "GUID", true) == 0 || fullTypeName.IndexOf("Guid", StringComparison.OrdinalIgnoreCase) > -1)
{
var tmpObj = mi.GetValue(obj, null);
if (tmpObj != null)
{
value = tmpObj.ToString().ToUpper();
if (dataBaseType == DataBaseType.Oracle)
value = Utility.DataHelper.DotNetToOracle(value);
else if (dataBaseType == DataBaseType.MySQL || dataBaseType == DataBaseType.Postgresql)
value = tmpObj.ToString().ToLower();
}
}
else if (string.Compare(propertyTypeName, "DateTime", true) == 0 || fullTypeName.IndexOf("DateTime", StringComparison.OrdinalIgnoreCase) > -1)
{
var tmpObj = mi.GetValue(obj, null);
if (tmpObj != null)
{
if (dataBaseType == DataBaseType.Oracle)
value = "to_date('" + ((DateTime)tmpObj).ToString("yyyy/MM/dd hh:mm:ss") + "','yyyy-mm-dd hh24-mi-ss')";
else if (dataBaseType == DataBaseType.Postgresql)
value = ((DateTime)tmpObj).ToString("yyyy-MM-dd HH:mm:ss");
else
value = tmpObj.ToString();
}
}
else if (string.Compare(propertyTypeName, "bool", true) == 0 || string.Compare(propertyTypeName, "boolean", true) == 0 || fullTypeName.IndexOf("bool", StringComparison.OrdinalIgnoreCase) > -1)
{
var tmpObj = mi.GetValue(obj, null);
if (tmpObj != null)
value = ((bool)tmpObj) ? "1" : "0";
}
else
{
var tmpObj = mi.GetValue(obj, null);
if (tmpObj != null)
value = tmpObj.ToString();
}
if (string.IsNullOrEmpty(value))
value = "NULL";
}
if (!string.IsNullOrEmpty(value))
fields[fieldName] = value;
}
if (fields.Count > 0)
{
string tableName = objType.Name;
if (string.Compare(objType.Namespace, "System.Data.Entity.DynamicProxies", true) == 0)
tableName = objType.BaseType.Name;
if (dataBaseType == DataBaseType.Postgresql)
tableName = "\"" + tableName + "\"";
StringBuilder upBuilder = new StringBuilder();
StringBuilder upFieldBuilder = new StringBuilder();
StringBuilder insertBuilder = new StringBuilder();
upBuilder.Append("UPDATE " + tableName + " SET ");
insertBuilder.Append("INSERT INTO " + tableName + "(");
foreach (var item in fields)
{
string field = item.Key;
if (dataBaseType == DataBaseType.Postgresql)
field = "\"" + field + "\"";
else if (DB_KEYWORDS.Any(t => (string.Compare(t, field, true) == 0)))//关键字加引号
field = (dataBaseType == DataBaseType.MySQL ? "`" : "\"") + field + (dataBaseType == DataBaseType.MySQL ? "`" : "\"");
insertBuilder.Append(field);
insertBuilder.Append(",");
}
insertBuilder.Length--;
insertBuilder.Append(") VALUES(");
string id = string.Empty;
foreach (var item in fields)
{
string field = item.Key;
string value = item.Value;
if (string.Compare(value, "NULL") != 0 && value.IndexOf("to_date", StringComparison.OrdinalIgnoreCase) == -1)
value = "'" + value + "'";
if (dataBaseType == DataBaseType.Postgresql)
field = "\"" + field + "\"";
else if (DB_KEYWORDS.Any(t => (string.Compare(t, field, true) == 0)))//关键字加引号
field = (dataBaseType == DataBaseType.MySQL ? "`" : "\"") + field + (dataBaseType == DataBaseType.MySQL ? "`" : "\"");
if (string.Compare(field, (dataBaseType == DataBaseType.Postgresql ? "\"ID\"" : "ID"), true) == 0)
id = value;
else
{
upBuilder.Append(field + "=" + value + ",");
upFieldBuilder.Append(field + "=" + value + ",");
}
insertBuilder.Append(value + ",");
}
upBuilder.Length--;
insertBuilder.Length--;
upFieldBuilder.Length--;
insertBuilder.Append(")");
if (dataBaseType == DataBaseType.Postgresql)
upBuilder.Append(" WHERE \"ID\"=" + id);
else
upBuilder.Append(" WHERE ID=" + id);
if (sqlType == 1)
{
result.Add(upBuilder.ToString() + ";");
}
else if (sqlType == 2)
{
result.Add(insertBuilder.ToString() + ";");
}
else if (dataBaseType == DataBaseType.Oracle)
result.Add(string.Format(" {0} ; if sql % notfound then {1} ; end if; ", upBuilder.ToString(), insertBuilder.ToString()));
else if (dataBaseType == DataBaseType.MySQL)
result.Add(string.Format(" {0} ON DUPLICATE KEY UPDATE {1}; ", insertBuilder.ToString(), upFieldBuilder.ToString()));
else if (dataBaseType == DataBaseType.Postgresql)
result.Add(string.Format(@" do language plpgsql $$ declare v_rowCount int:= 0; begin {0}; GET DIAGNOSTICS v_rowCount = ROW_COUNT; if (v_rowCount = 0) then {1}; end if; end $$;",
upBuilder.ToString(), insertBuilder.ToString()));
else
result.Add(string.Format("begin {0}; if @@RowCount = 0 begin {1} ; end end ", upBuilder.ToString(), insertBuilder.ToString()));
}
}
private void DoSynchFormConfigByOrg(Guid srcOrgId, List<Guid> destOrgIds, DateTime? startTime)
{
List<Guid> orgIds = new List<Guid>();
orgIds.Add(srcOrgId);
orgIds.AddRange(destOrgIds);
List<T_PF_FORM> destAddForms = new List<T_PF_FORM>();
List<T_PF_PAGE_EDIT> destAddEdits = new List<T_PF_PAGE_EDIT>();
List<T_PF_PAGE_EDIT_PANEL> destAddEditPanels = new List<T_PF_PAGE_EDIT_PANEL>();
List<T_PF_PARAM_ITEM> destAddParamItems = new List<T_PF_PARAM_ITEM>();
List<T_PF_PARAM_SCHEME> destAddParamSchemes = new List<T_PF_PARAM_SCHEME>();
List<T_PF_PARAM_SCHEME_DETAIL> destAddParamSchemeDetails = new List<T_PF_PARAM_SCHEME_DETAIL>();
List<T_PF_PAGE_TABLE_PANEL> destAddTablePanels = new List<T_PF_PAGE_TABLE_PANEL>();
List<T_PF_EDIT_COLUMN> destAddEditColumns = new List<T_PF_EDIT_COLUMN>();
List<T_PF_EDIT_COLUMN_FILTER> destAddEditColumnFilters = new List<T_PF_EDIT_COLUMN_FILTER>();
List<T_PF_EDIT_COLUMN_FILL_MAP> destAddEditColumnFillMaps = new List<T_PF_EDIT_COLUMN_FILL_MAP>();
List<T_PF_EDIT_COLUMN_FILL_MAP_D> destAddEditColumnFillMapDs = new List<T_PF_EDIT_COLUMN_FILL_MAP_D>();
List<T_PF_PAGE_CUSTOM> destAddCustoms = new List<T_PF_PAGE_CUSTOM>();
List<T_PF_PAGE_CHART> destAddCharts = new List<T_PF_PAGE_CHART>();
List<T_PF_PAGE_CHART_PARAM> destAddChartParams = new List<T_PF_PAGE_CHART_PARAM>();
List<T_PF_PAGE_TABLE> destAddTables = new List<T_PF_PAGE_TABLE>();
List<T_PF_COLUMN> destAddColums = new List<T_PF_COLUMN>();
List<T_PF_COLUMN_FILTER> destAddColumFilters = new List<T_PF_COLUMN_FILTER>();
List<T_PF_TABLE_PARAMS> destAddTableParams = new List<T_PF_TABLE_PARAMS>();
List<T_PF_QUERY> destAddQuerys = new List<T_PF_QUERY>();
List<T_PF_FORM_QUERY> destAddFormQuerys = new List<T_PF_FORM_QUERY>();
List<T_PF_PAGE_TREE> destAddTrees = new List<T_PF_PAGE_TREE>();
List<T_PF_TREE_COLUMN> destAddTreeColumns = new List<T_PF_TREE_COLUMN>();
List<T_PF_BTN> destAddBtns = new List<T_PF_BTN>();
List<T_PF_MENU> destAddMenus = new List<T_PF_MENU>();
List<T_PF_APPMENU> destAddAppMenus = new List<T_PF_APPMENU>();
List<T_PF_CLIENT_MENU> destAddClientMenus = new List<T_PF_CLIENT_MENU>();
List<T_PF_CODE_RULE> destAddCodeRules = new List<T_PF_CODE_RULE>();
List<T_PF_FORM> destUpdateForms = new List<T_PF_FORM>();
List<T_PF_PAGE_EDIT> destUpdateEdits = new List<T_PF_PAGE_EDIT>();
List<T_PF_PAGE_EDIT_PANEL> destUpdateEditPanels = new List<T_PF_PAGE_EDIT_PANEL>();
List<T_PF_PARAM_ITEM> destUpdateParamItems = new List<T_PF_PARAM_ITEM>();
List<T_PF_PARAM_SCHEME> destUpdateParamSchemes = new List<T_PF_PARAM_SCHEME>();
List<T_PF_PARAM_SCHEME_DETAIL> destUpdateParamSchemeDetails = new List<T_PF_PARAM_SCHEME_DETAIL>();
List<T_PF_PAGE_TABLE_PANEL> destUpdateTablePanels = new List<T_PF_PAGE_TABLE_PANEL>();
List<T_PF_EDIT_COLUMN> destUpdateEditColumns = new List<T_PF_EDIT_COLUMN>();
List<T_PF_EDIT_COLUMN_FILTER> destUpdateEditColumnFilters = new List<T_PF_EDIT_COLUMN_FILTER>();
List<T_PF_EDIT_COLUMN_FILL_MAP> destUpdateEditColumnFillMaps = new List<T_PF_EDIT_COLUMN_FILL_MAP>();
List<T_PF_EDIT_COLUMN_FILL_MAP_D> destUpdateEditColumnFillMapDs = new List<T_PF_EDIT_COLUMN_FILL_MAP_D>();
List<T_PF_PAGE_CUSTOM> destUpdateCustoms = new List<T_PF_PAGE_CUSTOM>();
List<T_PF_PAGE_CHART> destUpdateCharts = new List<T_PF_PAGE_CHART>();
List<T_PF_PAGE_CHART_PARAM> destUpdateChartParams = new List<T_PF_PAGE_CHART_PARAM>();
List<T_PF_PAGE_TABLE> destUpdateTables = new List<T_PF_PAGE_TABLE>();
List<T_PF_COLUMN> destUpdateColums = new List<T_PF_COLUMN>();
List<T_PF_COLUMN_FILTER> destUpdateColumFilters = new List<T_PF_COLUMN_FILTER>();
List<T_PF_TABLE_PARAMS> destUpdateTableParams = new List<T_PF_TABLE_PARAMS>();
List<T_PF_QUERY> destUpdateQuerys = new List<T_PF_QUERY>();
List<T_PF_FORM_QUERY> destUpdateFormQuerys = new List<T_PF_FORM_QUERY>();
List<T_PF_PAGE_TREE> destUpdateTrees = new List<T_PF_PAGE_TREE>();
List<T_PF_TREE_COLUMN> destUpdateTreeColumns = new List<T_PF_TREE_COLUMN>();
List<T_PF_BTN> destUpdateBtns = new List<T_PF_BTN>();
List<T_PF_MENU> destUpdateMenus = new List<T_PF_MENU>();
List<T_PF_APPMENU> destUpdateAppMenus = new List<T_PF_APPMENU>();
List<T_PF_CLIENT_MENU> destUpdateClientMenus = new List<T_PF_CLIENT_MENU>();
List<T_PF_CODE_RULE> destUpdateCodeRules = new List<T_PF_CODE_RULE>();
Dictionary<Guid, Dictionary<Guid, Guid>> entityRelations = new Dictionary<Guid, Dictionary<Guid, Guid>>();
Dictionary<Guid, Guid> tempRels = null;
List<Guid> updateFormIds = new List<Guid>();
#region
var paramItems = this.GetEntities<T_PF_PARAM_ITEM>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcParamItems = paramItems.Where(t => t.ORG_ID == srcOrgId).ToList();
List<Guid> paramItemIds = new List<Guid>();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PARAM_ITEM>(srcParamItems, item, tempRels, destAddParamItems, destUpdateParamItems, string.Empty, startTime, null,
(t) =>
{
return paramItems.FirstOrDefault(t1 => t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME);
},
null,
(t) =>
{
if (!paramItemIds.Contains(t.ID))
paramItemIds.Add(t.ID);
if (!paramItems.Any(t1 => t1.ID == t.ID))
paramItems.Add(t);
});
}
var paramSchemes = this.GetEntities<T_PF_PARAM_SCHEME>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcParamSchemes = paramSchemes.Where(t => t.ORG_ID == srcOrgId).ToList();
List<Guid> paramSchemeIds = new List<Guid>();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PARAM_SCHEME>(srcParamSchemes, item, tempRels, destAddParamSchemes, destUpdateParamSchemes, string.Empty, startTime, null,
(t) =>
{
return paramSchemes.FirstOrDefault(t1 => t1.ORG_ID == item && t1.CODE == t.CODE);
},
null,
(t) =>
{
if (!paramSchemeIds.Contains(t.ID))
paramSchemeIds.Add(t.ID);
if (!paramSchemes.Any(t1 => t1.ID == t.ID))
paramSchemes.Add(t);
});
}
var paramSchemeDetails = this.GetEntities<T_PF_PARAM_SCHEME_DETAIL>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcParamSchemeDetails = paramSchemeDetails.Where(t => t.ORG_ID == srcOrgId).ToList();
List<Guid> paramSchemeDetailIds = new List<Guid>();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PARAM_SCHEME_DETAIL>(srcParamSchemeDetails, item, tempRels, destAddParamSchemeDetails, destUpdateParamSchemeDetails, "PARAM_SCHEME_ID", startTime, (src, dest, rels) =>
{
var srcItem = paramItems.FirstOrDefault(t1 => t1.ID == src.PARAM_ITEM_ID);
if (srcItem != null)
{
var desItem = paramItems.FirstOrDefault(t => t.ORG_ID == item && srcItem.CODE == t.CODE);
if (desItem != null)
dest.PARAM_ITEM_ID = desItem.ID;
}
},
(t) =>
{
var srcItem = paramItems.FirstOrDefault(t1 => t1.ID == t.PARAM_ITEM_ID);
List<Guid> destSchemeIds = new List<Guid>();
if (srcItem != null)
destSchemeIds = paramItems.Where(t1 => t1.CODE == srcItem.CODE).Select(t1 => t1.ID).ToList();
return paramSchemeDetails.FirstOrDefault(t1 => t1.ORG_ID == item && destSchemeIds.Contains(t1.ID));
},
null,
(t) =>
{
if (!paramSchemeDetailIds.Contains(t.ID))
paramSchemeDetailIds.Add(t.ID);
if (!paramSchemeDetails.Any(t1 => t1.ID == t.ID))
paramSchemeDetails.Add(t);
});
}
#endregion
#region
//表单
var forms = this.GetEntities<T_PF_FORM>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcForms = forms.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_FORM>(srcForms, item, tempRels, destAddForms, destUpdateForms, string.Empty, startTime, null,
(t) =>
{
return forms.FirstOrDefault(t1 => t1.ORG_ID == item && t1.CODE == t.CODE);
},
null,
(t) =>
{
if (!updateFormIds.Contains(t.ID))
updateFormIds.Add(t.ID);
if (!forms.Any(t1 => t1.ID == t.ID))
forms.Add(t);
});
}
#region
var pageEdits = this.GetEntities<T_PF_PAGE_EDIT>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcPageEdits = pageEdits.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrcOnTree<T_PF_PAGE_EDIT>(srcPageEdits, null, null, item, tempRels, destAddEdits, destUpdateEdits, "PAGE_FORM_ID", startTime,
(src, dest, rels) =>
{
dest.NAV_PROPERTY = src.NAV_PROPERTY;
T_PF_PARAM_SCHEME destParamScheme = null;
if (src.PARAM_SCHEME_ID != null)
{
var srcScheme = paramSchemes.FirstOrDefault(t1 => t1.ID == src.PARAM_SCHEME_ID);
if (srcScheme != null)
destParamScheme = paramSchemes.FirstOrDefault(t1 => t1.ORG_ID == dest.ORG_ID && t1.CODE == srcScheme.CODE);
}
if (destParamScheme != null)
dest.PARAM_SCHEME_ID = destParamScheme.ID;
else
dest.PARAM_SCHEME_ID = null;
},
(src, destParentId) =>
{
Guid destPageFormId;
if (src.PAGE_FORM_ID != null && tempRels.TryGetValue(src.PAGE_FORM_ID.Value, out destPageFormId))
{
return pageEdits.FirstOrDefault(t1 => t1.PAGE_FORM_ID == destPageFormId &&
t1.ORG_ID == item && t1.CODE == src.CODE && t1.PARENT_ID == destParentId);
}
return null;
},
null,
t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
if (!pageEdits.Any(t1 => t1.ID == t.ID))
pageEdits.Add(t);
});
}
var editPanels = this.GetEntities<T_PF_PAGE_EDIT_PANEL>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcEditPanels = editPanels.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PAGE_EDIT_PANEL>(srcEditPanels, item, tempRels, destAddEditPanels, destUpdateEditPanels, "PAGE_EDIT_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.PAGE_EDIT_ID, out destId))
{
return editPanels.FirstOrDefault(t1 => t1.PAGE_EDIT_ID == destId &&
t1.ORG_ID == item && t1.LABEL == t.LABEL);
}
return null;
},
null,
t =>
{
var pageEdit = pageEdits.FirstOrDefault(t1 => t1.ID == t.PAGE_EDIT_ID);
if (pageEdit != null)
{
if (pageEdit.PAGE_FORM_ID != null && !updateFormIds.Contains(pageEdit.PAGE_FORM_ID.Value))
updateFormIds.Add(pageEdit.PAGE_FORM_ID.Value);
}
if (!editPanels.Any(t1 => t1.ID == t.ID))
editPanels.Add(t);
});
}
var editColumns = this.GetEntities<T_PF_EDIT_COLUMN>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcEditColumns = editColumns.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_EDIT_COLUMN>(srcEditColumns, item, tempRels, destAddEditColumns, destUpdateEditColumns, "PAGE_EDIT_ID", startTime,
(src, dest, rel) =>
{
Guid temp;
if (src.PAGE_EDIT_PANEL_ID != null && rel.TryGetValue(src.PAGE_EDIT_PANEL_ID.Value, out temp))
dest.PAGE_EDIT_PANEL_ID = temp;
},
(t) =>
{
Guid destId;
if (tempRels.TryGetValue(t.PAGE_EDIT_ID, out destId))
{
return editColumns.FirstOrDefault(t1 => t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME
&& t1.PAGE_EDIT_ID == destId);
}
return null;
},
null,
(t) =>
{
var pageEdit = pageEdits.FirstOrDefault(t1 => t1.ID == t.PAGE_EDIT_ID);
if (pageEdit != null)
{
if (pageEdit.PAGE_FORM_ID != null && !updateFormIds.Contains(pageEdit.PAGE_FORM_ID.Value))
updateFormIds.Add(pageEdit.PAGE_FORM_ID.Value);
}
if (!editColumns.Any(t1 => t1.ID == t.ID))
editColumns.Add(t);
});
}
var editColumnFilters = this.GetEntities<T_PF_EDIT_COLUMN_FILTER>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcEditColumnFilters = editColumnFilters.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_EDIT_COLUMN_FILTER>(srcEditColumnFilters, item, tempRels, destAddEditColumnFilters, destUpdateEditColumnFilters, "EDIT_COLUMN_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.EDIT_COLUMN_ID, out destId))
{
return editColumnFilters.FirstOrDefault(t1 => t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME
&& t1.OPERATION == t.OPERATION && t1.VALUE == t.VALUE && t1.IS_CUSTOM == t.IS_CUSTOM
&& t1.EDIT_COLUMN_ID == destId);
}
return null;
},
null,
t =>
{
var editColumn = editColumns.FirstOrDefault(t1 => t1.ID == t.EDIT_COLUMN_ID);
if (editColumn != null)
{
var pageEdit = pageEdits.FirstOrDefault(t1 => t1.ID == editColumn.PAGE_EDIT_ID);
if (pageEdit != null)
{
if (pageEdit.PAGE_FORM_ID != null && !updateFormIds.Contains(pageEdit.PAGE_FORM_ID.Value))
updateFormIds.Add(pageEdit.PAGE_FORM_ID.Value);
}
}
if (!editColumnFilters.Any(t1 => t1.ID == t.ID))
editColumnFilters.Add(t);
});
}
var editColumnFillMaps = this.GetEntities<T_PF_EDIT_COLUMN_FILL_MAP>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcEditColumnFillMaps = editColumnFillMaps.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_EDIT_COLUMN_FILL_MAP>(srcEditColumnFillMaps, item, tempRels, destAddEditColumnFillMaps, destUpdateEditColumnFillMaps, "EDIT_COLUMN_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.EDIT_COLUMN_ID, out destId))
{
return editColumnFillMaps.FirstOrDefault(t1 => t1.ORG_ID == item && t1.SRC_NAV == t.SRC_NAV
&& t1.EDIT_COLUMN_ID == destId);
}
return null;
},
null,
t =>
{
var editColumn = editColumns.FirstOrDefault(t1 => t1.ID == t.EDIT_COLUMN_ID);
if (editColumn != null)
{
var pageEdit = pageEdits.FirstOrDefault(t1 => t1.ID == editColumn.PAGE_EDIT_ID);
if (pageEdit != null)
{
if (pageEdit.PAGE_FORM_ID != null && !updateFormIds.Contains(pageEdit.PAGE_FORM_ID.Value))
updateFormIds.Add(pageEdit.PAGE_FORM_ID.Value);
}
}
if (!editColumnFillMaps.Any(t1 => t1.ID == t.ID))
editColumnFillMaps.Add(t);
});
}
var editColumnFillMapDetails = this.GetEntities<T_PF_EDIT_COLUMN_FILL_MAP_D>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcEditColumnFillMapDetails = editColumnFillMapDetails.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_EDIT_COLUMN_FILL_MAP_D>(srcEditColumnFillMapDetails, item, tempRels, destAddEditColumnFillMapDs, destUpdateEditColumnFillMapDs, "EDIT_COLUMN_FILL_MAP_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.EDIT_COLUMN_FILL_MAP_ID, out destId))
{
return editColumnFillMapDetails.FirstOrDefault(t1 => t1.ORG_ID == item && t1.SRC_FIELD_NAME == t.SRC_FIELD_NAME
&& t1.DEST_FIELD_NAME == t.DEST_FIELD_NAME && t1.EDIT_COLUMN_FILL_MAP_ID == destId);
}
return null;
},
null,
t =>
{
var map = editColumnFillMaps.FirstOrDefault(t1 => t.ID == t.EDIT_COLUMN_FILL_MAP_ID);
if (map != null)
{
var editColumn = editColumns.FirstOrDefault(t1 => t1.ID == map.EDIT_COLUMN_ID);
if (editColumn != null)
{
var pageEdit = pageEdits.FirstOrDefault(t1 => t1.ID == editColumn.PAGE_EDIT_ID);
if (pageEdit != null)
{
if (pageEdit.PAGE_FORM_ID != null && !updateFormIds.Contains(pageEdit.PAGE_FORM_ID.Value))
updateFormIds.Add(pageEdit.PAGE_FORM_ID.Value);
}
}
}
if (!editColumnFillMapDetails.Any(t1 => t1.ID == t.ID))
editColumnFillMapDetails.Add(t);
});
}
#endregion
#region
var pageCustoms = this.GetEntities<T_PF_PAGE_CUSTOM>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcPageCustoms = pageCustoms.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PAGE_CUSTOM>(srcPageCustoms, item, tempRels, destAddCustoms, destUpdateCustoms, "PAGE_FORM_ID", startTime, null,
t =>
{
Guid destPageFormId;
if (t.PAGE_FORM_ID != null && tempRels.TryGetValue(t.PAGE_FORM_ID.Value, out destPageFormId))
{
return pageCustoms.FirstOrDefault(t1 => t1.PAGE_FORM_ID == destPageFormId &&
t1.ORG_ID == item && t1.COMPONENT_NAME == t.COMPONENT_NAME);
}
return null;
},
null,
t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
if (!pageCustoms.Any(t1 => t1.ID == t.ID))
pageCustoms.Add(t);
});
}
#endregion
#region
var pageCharts = this.GetEntities<T_PF_PAGE_CHART>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcPageCharts = pageCharts.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PAGE_CHART>(srcPageCharts, item, tempRels, destAddCharts, destUpdateCharts, "PAGE_FORM_ID", startTime, null,
t =>
{
Guid destPageFormId;
if (t.PAGE_FORM_ID != null && tempRels.TryGetValue(t.PAGE_FORM_ID.Value, out destPageFormId))
{
return pageCharts.FirstOrDefault(t1 => t1.PAGE_FORM_ID == destPageFormId &&
t1.ORG_ID == item && t1.CODE == t.CODE);
}
return null;
},
null,
t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
if (!pageCharts.Any(t1 => t1.ID == t.ID))
pageCharts.Add(t);
});
}
var pageChartParams = this.GetEntities<T_PF_PAGE_CHART_PARAM>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcPageChartParams = pageChartParams.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PAGE_CHART_PARAM>(srcPageChartParams, item, tempRels, destAddChartParams, destUpdateChartParams, "PAGE_CHART_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.PAGE_CHART_ID, out destId))
{
return pageChartParams.FirstOrDefault(t1 => t1.PAGE_CHART_ID == destId &&
t1.FIELD_NAME == t.FIELD_NAME && t1.OPERATION == t.OPERATION && t1.VALUE == t.VALUE &&
t1.IS_CUSTOM == t.IS_CUSTOM && t1.ORG_ID == item);
}
return null;
},
null,
t =>
{
var pageChart = pageCharts.FirstOrDefault(t1 => t.ID == t.PAGE_CHART_ID);
if (pageChart != null)
{
if (pageChart.PAGE_FORM_ID != null && !updateFormIds.Contains(pageChart.PAGE_FORM_ID.Value))
updateFormIds.Add(pageChart.PAGE_FORM_ID.Value);
}
if (!pageChartParams.Any(t1 => t1.ID == t.ID))
pageChartParams.Add(t);
});
}
#endregion
#region
var pageTables = this.GetEntities<T_PF_PAGE_TABLE>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcPageTables = pageTables.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrcOnTree<T_PF_PAGE_TABLE>(srcPageTables, null, null, item, tempRels, destAddTables, destUpdateTables, "PAGE_FORM_ID", startTime, (src, dest, rels) =>
{
T_PF_PARAM_SCHEME destParamScheme = null;
if (src.PARAM_SCHEME_ID != null)
{
var srcScheme = paramSchemes.FirstOrDefault(t1 => t1.ID == src.PARAM_SCHEME_ID);
if (srcScheme != null)
destParamScheme = paramSchemes.FirstOrDefault(t1 => t1.ORG_ID == dest.ORG_ID && t1.CODE == srcScheme.CODE);
}
if (destParamScheme != null)
dest.PARAM_SCHEME_ID = destParamScheme.ID;
else
dest.PARAM_SCHEME_ID = null;
},
(src, destParentId) =>
{
Guid destPageFormId;
if (src.PAGE_FORM_ID != null && tempRels.TryGetValue(src.PAGE_FORM_ID.Value, out destPageFormId))
{
return pageTables.FirstOrDefault(t1 => t1.PAGE_FORM_ID == destPageFormId &&
t1.ORG_ID == item && t1.CODE == src.CODE && t1.PARENT_ID == destParentId);
}
return null;
},
null,
t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
if (!pageTables.Any(t1 => t1.ID == t.ID))
pageTables.Add(t);
});
}
var tablePanels = this.GetEntities<T_PF_PAGE_TABLE_PANEL>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcTablePanels = tablePanels.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PAGE_TABLE_PANEL>(srcTablePanels, item, tempRels, destAddTablePanels, destUpdateTablePanels, "PAGE_TABLE_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.PAGE_TABLE_ID, out destId))
{
return tablePanels.FirstOrDefault(t1 => t1.PAGE_TABLE_ID == destId &&
t1.ORG_ID == item && t1.LABEL == t.LABEL);
}
return null;
},
null,
t =>
{
var pageEdit = pageTables.FirstOrDefault(t1 => t1.ID == t.PAGE_TABLE_ID);
if (pageEdit != null)
{
if (pageEdit.PAGE_FORM_ID != null && !updateFormIds.Contains(pageEdit.PAGE_FORM_ID.Value))
updateFormIds.Add(pageEdit.PAGE_FORM_ID.Value);
}
if (!tablePanels.Any(t1 => t1.ID == t.ID))
tablePanels.Add(t);
});
}
var columns = this.GetEntities<T_PF_COLUMN>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcColumns = columns.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_COLUMN>(srcColumns, item, tempRels, destAddColums, destUpdateColums, "PAGE_TABLE_ID", startTime,
(src, dest, rel) =>
{
Guid temp;
if (src.PAGE_TABLE_PANEL_ID != null && rel.TryGetValue(src.PAGE_TABLE_PANEL_ID.Value, out temp))
dest.PAGE_TABLE_PANEL_ID = temp;
},
t =>
{
Guid destId;
if (t.PAGE_TABLE_ID != null && tempRels.TryGetValue(t.PAGE_TABLE_ID.Value, out destId))
{
return columns.FirstOrDefault(t1 => t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME
&& t1.PAGE_TABLE_ID == destId);
}
return null;
},
null,
t =>
{
var pageTable = pageTables.FirstOrDefault(t1 => t1.ID == t.PAGE_TABLE_ID);
if (pageTable != null)
{
if (pageTable.PAGE_FORM_ID != null && !updateFormIds.Contains(pageTable.PAGE_FORM_ID.Value))
updateFormIds.Add(pageTable.PAGE_FORM_ID.Value);
}
if (!columns.Any(t1 => t1.ID == t.ID))
columns.Add(t);
});
}
var columnFilters = this.GetEntities<T_PF_COLUMN_FILTER>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcColumnFilters = columnFilters.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_COLUMN_FILTER>(srcColumnFilters, item, tempRels, destAddColumFilters, destUpdateColumFilters, "COLUMN_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.COLUMN_ID, out destId))
{
return srcColumnFilters.FirstOrDefault(t1 => t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME
&& t1.OPERATION == t.OPERATION && t1.VALUE == t.VALUE && t1.IS_CUSTOM == t.IS_CUSTOM
&& t1.COLUMN_ID == destId);
}
return null;
},
null,
t =>
{
var column = columns.FirstOrDefault(t1 => t1.ID == t.COLUMN_ID);
if (column != null)
{
var pageTable = pageTables.FirstOrDefault(t1 => t1.ID == column.PAGE_TABLE_ID);
if (pageTable != null)
{
if (pageTable.PAGE_FORM_ID != null && !updateFormIds.Contains(pageTable.PAGE_FORM_ID.Value))
updateFormIds.Add(pageTable.PAGE_FORM_ID.Value);
}
}
if (!columnFilters.Any(t1 => t1.ID == t.ID))
columnFilters.Add(t);
});
}
var tableParams = this.GetEntities<T_PF_TABLE_PARAMS>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcTableParams = tableParams.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_TABLE_PARAMS>(srcTableParams, item, tempRels, destAddTableParams, destUpdateTableParams, "PAGE_TABLE_ID", startTime, null,
t =>
{
Guid destId;
if (tempRels.TryGetValue(t.PAGE_TABLE_ID, out destId))
{
return tableParams.FirstOrDefault(t1 => t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME
&& t1.PAGE_TABLE_ID == destId);
}
return null;
},
null,
t =>
{
var pageTable = pageTables.FirstOrDefault(t1 => t1.ID == t.PAGE_TABLE_ID);
if (pageTable != null)
{
if (pageTable.PAGE_FORM_ID != null && !updateFormIds.Contains(pageTable.PAGE_FORM_ID.Value))
updateFormIds.Add(pageTable.PAGE_FORM_ID.Value);
}
if (!tableParams.Any(t1 => t1.ID == t.ID))
tableParams.Add(t);
});
}
#endregion
#region
var formQuerys = this.GetEntities<T_PF_FORM_QUERY>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcFormQuerys = formQuerys.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_FORM_QUERY>(srcFormQuerys, item, tempRels, destAddFormQuerys, destUpdateFormQuerys, "PAGE_FORM_ID", startTime, null,
t =>
{
Guid destPageFormId;
if (t.PAGE_FORM_ID != null && tempRels.TryGetValue(t.PAGE_FORM_ID.Value, out destPageFormId))
{
return formQuerys.FirstOrDefault(t1 => t1.PAGE_FORM_ID == destPageFormId &&
t1.ORG_ID == item && t1.CODE == t.CODE);
}
return null;
},
null,
t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
if (!formQuerys.Any(t1 => t1.ID == t.ID))
formQuerys.Add(t);
});
}
var querys = this.GetEntities<T_PF_QUERY>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcQuerys = querys.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_QUERY>(srcQuerys, item, tempRels, destAddQuerys, destUpdateQuerys, "PAGE_FORM_ID", startTime, (src, dest, rels) =>
{
Guid formQueryId;
if (src.PAGE_FORM_QUERY_ID != null && rels.TryGetValue(src.PAGE_FORM_QUERY_ID.Value, out formQueryId))
dest.PAGE_FORM_QUERY_ID = formQueryId;
},
t =>
{
Guid destId;
if (t.PAGE_FORM_QUERY_ID != null && tempRels.TryGetValue(t.PAGE_FORM_QUERY_ID.Value, out destId))
{
return querys.FirstOrDefault(t1 => t1.ORG_ID == item && t1.QUERY_NAME == t.QUERY_NAME &&
t1.OP_DEFAULT == t.OP_DEFAULT && t1.DATA_VALUE == t.DATA_VALUE && t1.IS_CUSTOM == t.IS_CUSTOM
&& t1.PAGE_FORM_QUERY_ID == destId);
}
return null;
},
null,
t =>
{
var formQury = formQuerys.FirstOrDefault(t1 => t1.ID == t.PAGE_FORM_QUERY_ID);
if (formQury != null)
{
if (formQury.PAGE_FORM_ID != null && !updateFormIds.Contains(formQury.PAGE_FORM_ID.Value))
updateFormIds.Add(formQury.PAGE_FORM_ID.Value);
}
if (!querys.Any(t1 => t1.ID == t.ID))
querys.Add(t);
});
}
#endregion
#region
var pageTrees = this.GetEntities<T_PF_PAGE_TREE>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcPageTrees = pageTrees.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_PAGE_TREE>(srcPageTrees, item, tempRels, destAddTrees, destUpdateTrees, "PAGE_FORM_ID", startTime, null,
t =>
{
Guid destPageFormId;
if (t.PAGE_FORM_ID != null && tempRels.TryGetValue(t.PAGE_FORM_ID.Value, out destPageFormId))
{
return pageTrees.FirstOrDefault(t1 => t1.PAGE_FORM_ID == destPageFormId &&
t1.ORG_ID == item && t1.CODE == t.CODE);
}
return null;
},
null,
t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
if (!pageTrees.Any(t1 => t1.ID == t.ID))
pageTrees.Add(t);
});
}
var treeColumns = this.GetEntities<T_PF_TREE_COLUMN>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcTreeColumns = treeColumns.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_TREE_COLUMN>(srcTreeColumns, item, tempRels, destAddTreeColumns, destUpdateTreeColumns, "PAGE_TREE_ID", startTime, null,
t =>
{
Guid destPageFormId;
if (tempRels.TryGetValue(t.PAGE_TREE_ID, out destPageFormId))
{
return treeColumns.FirstOrDefault(t1 => t1.PAGE_TREE_ID == destPageFormId &&
t1.ORG_ID == item && t1.FIELD_NAME == t.FIELD_NAME);
}
return null;
},
null,
t =>
{
var pageTree = pageTrees.FirstOrDefault(t1 => t1.ID == t.PAGE_TREE_ID);
if (pageTree != null)
{
if (pageTree.PAGE_FORM_ID != null && !updateFormIds.Contains(pageTree.PAGE_FORM_ID.Value))
updateFormIds.Add(pageTree.PAGE_FORM_ID.Value);
}
if (!treeColumns.Any(t1 => t1.ID == t.ID))
treeColumns.Add(t);
});
}
#endregion
#region
var btns = this.GetEntities<T_PF_BTN>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcBtns = btns.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_BTN>(srcBtns, item, tempRels, destAddBtns, destUpdateBtns, string.Empty, startTime,
(src, dest, rels) =>
{
Guid destId;
if (src.PAGE_CUSTOM_FORM_ID != null && rels.TryGetValue(src.PAGE_CUSTOM_FORM_ID.Value, out destId))
{
dest.PAGE_CUSTOM_FORM_ID = destId;
dest.PAGE_ID = destId;
}
if (src.PAGE_TABLE_ID != null && rels.TryGetValue(src.PAGE_TABLE_ID.Value, out destId))
{
dest.PAGE_TABLE_ID = destId;
dest.PAGE_ID = destId;
}
if (src.PAGE_EDIT_ID != null && rels.TryGetValue(src.PAGE_EDIT_ID.Value, out destId))
{
dest.PAGE_EDIT_ID = destId;
dest.PAGE_ID = destId;
}
},
t =>
{
Guid destId;
if (t.PAGE_CUSTOM_FORM_ID != null && tempRels.TryGetValue(t.PAGE_CUSTOM_FORM_ID.Value, out destId))
return btns.FirstOrDefault(t1 => t1.PAGE_CUSTOM_FORM_ID == destId && t1.ORG_ID == item &&
t1.LABEL == t.LABEL && t1.BTN_TYPE == t.BTN_TYPE && t1.BTN_FUN_TYPE == t.BTN_FUN_TYPE);
if (t.PAGE_TABLE_ID != null && tempRels.TryGetValue(t.PAGE_TABLE_ID.Value, out destId))
return btns.FirstOrDefault(t1 => t1.PAGE_TABLE_ID == destId && t1.ORG_ID == item &&
t1.LABEL == t.LABEL && t1.BTN_TYPE == t.BTN_TYPE && t1.BTN_FUN_TYPE == t.BTN_FUN_TYPE);
if (t.PAGE_EDIT_ID != null && tempRels.TryGetValue(t.PAGE_EDIT_ID.Value, out destId))
return btns.FirstOrDefault(t1 => t1.PAGE_EDIT_ID == destId && t1.ORG_ID == item &&
t1.LABEL == t.LABEL && t1.BTN_TYPE == t.BTN_TYPE && t1.BTN_FUN_TYPE == t.BTN_FUN_TYPE);
return null;
},
null,
t =>
{
Guid? formId = null;
if (t.PAGE_CUSTOM_FORM_ID != null)
{
var pageCustom = pageCustoms.FirstOrDefault(t1 => t.ID == t.PAGE_CUSTOM_FORM_ID);
if (pageCustom != null)
formId = pageCustom.PAGE_FORM_ID;
}
if (t.PAGE_TABLE_ID != null)
{
var pageTable = pageTables.FirstOrDefault(t1 => t.ID == t.PAGE_TABLE_ID);
if (pageTable != null)
formId = pageTable.PAGE_FORM_ID;
}
if (t.PAGE_EDIT_ID != null)
{
var pageEdit = pageEdits.FirstOrDefault(t1 => t.ID == t.PAGE_EDIT_ID);
if (pageEdit != null)
formId = pageEdit.PAGE_FORM_ID;
else
{
var pageTree = pageTrees.FirstOrDefault(t1 => t.ID == t.PAGE_EDIT_ID);
if (pageTree != null)
formId = pageTree.PAGE_FORM_ID;
}
}
if (formId != null && !updateFormIds.Contains(formId.Value))
updateFormIds.Add(formId.Value);
if (!btns.Any(t1 => t1.ID == t.ID))
btns.Add(t);
});
}
#endregion
#endregion
#region
var menus = this.GetEntities<T_PF_MENU>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcMenus = menus.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrcOnTree<T_PF_MENU>(srcMenus, null, null, item, tempRels, destAddMenus, destUpdateMenus, "MENU_FORM_ID", startTime, null,
(src, destParentId) =>
{
return menus.FirstOrDefault(t1 =>
t1.ORG_ID == item && t1.NAME == src.NAME && t1.PARENT_ID == destParentId);
},
null,
t =>
{
if (!menus.Any(t1 => t1.ID == t.ID))
menus.Add(t);
});
}
var appMenus = this.GetEntities<T_PF_APPMENU>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcAppMenus = appMenus.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrcOnTree<T_PF_APPMENU>(srcAppMenus, null, null, item, tempRels, destAddAppMenus, destUpdateAppMenus, "MENU_FORM_ID", startTime, null,
(src, destParentId) =>
{
return appMenus.FirstOrDefault(t1 =>
t1.ORG_ID == item && t1.NAME == src.NAME && t1.PARENT_ID == destParentId);
},
null,
t =>
{
if (!appMenus.Any(t1 => t1.ID == t.ID))
appMenus.Add(t);
});
}
var clientMenus = this.GetEntities<T_PF_CLIENT_MENU>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcClientMenus = clientMenus.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrcOnTree<T_PF_CLIENT_MENU>(srcClientMenus, null, null, item, tempRels, destAddClientMenus, destUpdateClientMenus, "MENU_FORM_ID", startTime, null,
(src, destParentId) =>
{
return clientMenus.FirstOrDefault(t1 =>
t1.ORG_ID == item && t1.NAME == src.NAME && t1.PARENT_ID == destParentId);
},
null,
t =>
{
if (!clientMenus.Any(t1 => t1.ID == t.ID))
clientMenus.Add(t);
});
}
#endregion
#region
var codeRules = this.GetEntities<T_PF_CODE_RULE>(t => orgIds.Contains(t.ORG_ID ?? Guid.Empty), new BaseFilter()).ToList();
var srcCodeRules = codeRules.Where(t => t.ORG_ID == srcOrgId).ToList();
foreach (var item in destOrgIds)
{
if (!entityRelations.TryGetValue(item, out tempRels))
{
tempRels = new Dictionary<Guid, Guid>();
entityRelations.Add(item, tempRels);
}
GetConfigBySrc<T_PF_CODE_RULE>(srcCodeRules, item, tempRels, destAddCodeRules, destUpdateCodeRules, string.Empty, startTime, null,
t =>
{
return codeRules.FirstOrDefault(t1 => t1.CODE_TYPE == t.CODE_TYPE && t1.ORG_ID == item);
},
null,
t =>
{
if (!codeRules.Any(t1 => t1.ID == t.ID))
codeRules.Add(t);
});
}
if (destAddCodeRules.Any())
destAddCodeRules.ForEach(t => t.CURRENT_DATA = null);
#endregion
#region
UnifiedCommit(() =>
{
this.BantchAddEntityNoCommit(destAddForms);
this.BantchAddEntityNoCommit(destAddParamItems);
this.BantchAddEntityNoCommit(destAddParamSchemes);
this.BantchAddEntityNoCommit(destAddParamSchemeDetails);
this.TreeBantchAddEntityNoCommit(destAddEdits);
this.BantchAddEntityNoCommit(destAddEditPanels);
this.BantchAddEntityNoCommit(destAddEditColumns);
this.BantchAddEntityNoCommit(destAddEditColumnFilters);
this.BantchAddEntityNoCommit(destAddEditColumnFillMaps);
this.BantchAddEntityNoCommit(destAddEditColumnFillMapDs);
this.BantchAddEntityNoCommit(destAddCustoms);
this.BantchAddEntityNoCommit(destAddCharts);
this.BantchAddEntityNoCommit(destAddChartParams);
this.TreeBantchAddEntityNoCommit(destAddTables);
this.BantchAddEntityNoCommit(destAddTablePanels);
this.BantchAddEntityNoCommit(destAddColums);
this.BantchAddEntityNoCommit(destAddColumFilters);
this.BantchAddEntityNoCommit(destAddTableParams);
this.BantchAddEntityNoCommit(destAddFormQuerys);
this.BantchAddEntityNoCommit(destAddQuerys);
this.BantchAddEntityNoCommit(destAddTrees);
this.BantchAddEntityNoCommit(destAddTreeColumns);
this.BantchAddEntityNoCommit(destAddBtns);
this.TreeBantchAddEntityNoCommit(destAddMenus);
this.TreeBantchAddEntityNoCommit(destAddAppMenus);
this.TreeBantchAddEntityNoCommit(destAddClientMenus);
this.BantchAddEntityNoCommit(destAddCodeRules);
this.BantchUpdateEntityNoCommit(destUpdateForms);
this.BantchUpdateEntityNoCommit(destUpdateParamItems);
this.BantchUpdateEntityNoCommit(destUpdateParamSchemes);
this.BantchUpdateEntityNoCommit(destUpdateParamSchemeDetails);
this.TreeBantchUpdateEntityNoCommit(destUpdateEdits);
this.BantchUpdateEntityNoCommit(destUpdateEditPanels);
this.BantchUpdateEntityNoCommit(destUpdateTablePanels);
this.BantchUpdateEntityNoCommit(destUpdateEditColumns);
this.BantchUpdateEntityNoCommit(destUpdateEditColumnFilters);
this.BantchUpdateEntityNoCommit(destUpdateEditColumnFillMaps);
this.BantchUpdateEntityNoCommit(destUpdateEditColumnFillMapDs);
this.BantchUpdateEntityNoCommit(destUpdateCustoms);
this.BantchUpdateEntityNoCommit(destUpdateCharts);
this.BantchUpdateEntityNoCommit(destUpdateChartParams);
this.TreeBantchUpdateEntityNoCommit(destUpdateTables);
this.BantchUpdateEntityNoCommit(destUpdateColums);
this.BantchUpdateEntityNoCommit(destUpdateColumFilters);
this.BantchUpdateEntityNoCommit(destUpdateTableParams);
this.BantchUpdateEntityNoCommit(destUpdateFormQuerys);
this.BantchUpdateEntityNoCommit(destUpdateQuerys);
this.BantchUpdateEntityNoCommit(destUpdateTrees);
this.BantchUpdateEntityNoCommit(destUpdateTreeColumns);
this.BantchUpdateEntityNoCommit(destUpdateBtns);
this.TreeBantchUpdateEntityNoCommit(destUpdateMenus);
this.TreeBantchUpdateEntityNoCommit(destUpdateAppMenus);
this.TreeBantchUpdateEntityNoCommit(destUpdateClientMenus);
this.BantchUpdateEntityNoCommit(destUpdateCodeRules);
});
#region
Dictionary<Guid, List<string>> tempCookies = new Dictionary<Guid, List<string>>();
var schemeIds = paramSchemeDetails.Where(t1 => paramSchemeDetailIds.Contains(t1.ID) || paramItemIds.Contains(t1.PARAM_ITEM_ID)).Select(t => t.PARAM_SCHEME_ID).ToList();
var allParamSchemeIds = paramSchemes.Where(t => paramSchemeIds.Contains(t.ID) || schemeIds.Contains(t.ID)).Select(t => t.ID).ToList();
if (allParamSchemeIds.Any())
{
var temppageTables = pageTables.Where(t => allParamSchemeIds.Contains(t.PARAM_SCHEME_ID ?? Guid.Empty)).ToList();
temppageTables.ForEach(t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
List<string> list = null;
if (!tempCookies.TryGetValue(t.ORG_ID.Value, out list))
{
list = new List<string>();
tempCookies.Add(t.ORG_ID.Value, list);
}
list.Add(string.Format("form_config_tablebase_{0}_{1}", t.ID, t.ORG_ID.Value));
var tempForm = forms.FirstOrDefault(t1 => t1.ID == t.PAGE_FORM_ID);
if (tempForm != null)
{
list.Add(string.Format("form_config_table_{0}_{1}_{2}", tempForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString())));
list.Add(string.Format("form_config_table_{0}_{1}_{2}_{3}", tempForm.CODE, t.ORG_ID, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString()),
t.ID));
}
});
var temppageEdits = this.GetEntities<T_PF_PAGE_EDIT>(t => allParamSchemeIds.Contains(t.PARAM_SCHEME_ID ?? Guid.Empty), new BaseFilter()).ToList();
temppageEdits.ForEach(t =>
{
if (t.PAGE_FORM_ID != null && !updateFormIds.Contains(t.PAGE_FORM_ID.Value))
updateFormIds.Add(t.PAGE_FORM_ID.Value);
});
}
#endregion
List<T_PF_PAGE_TABLE> versionPageTables = new List<T_PF_PAGE_TABLE>();
List<T_PF_COLUMN> versionColumns = new List<T_PF_COLUMN>();
List<T_PF_PAGE_TABLE_PANEL> versionPageTablePanels = new List<T_PF_PAGE_TABLE_PANEL>();
if (destAddTables.Any()) versionPageTables.AddRange(destAddTables);
if (destUpdateTables.Any()) versionPageTables.AddRange(destUpdateTables);
if (destAddColums.Any()) versionColumns.AddRange(destAddColums);
if (destUpdateColums.Any()) versionColumns.AddRange(destUpdateColums);
if (destAddTablePanels.Any()) versionPageTablePanels.AddRange(destAddTablePanels);
if (destUpdateTablePanels.Any()) versionPageTablePanels.AddRange(destUpdateTablePanels);
AddFormConfigVersion(updateFormIds, versionPageTables, versionColumns,
versionPageTablePanels, tempCookies);
#endregion
}
public void AddFormConfigVersion(List<Guid> formIds, List<T_PF_PAGE_TABLE> pageTables,
List<T_PF_COLUMN> columns, List<T_PF_PAGE_TABLE_PANEL> pageTablePanels,
Dictionary<Guid, List<string>> otherCookies)
{
//List<T_PF_FORM_CONFIG_VERSION> formConfigVersions = new List<T_PF_FORM_CONFIG_VERSION>();
//List<T_PF_FORM_CONFIG_VERSION_D> formConfigVersionDetails = new List<T_PF_FORM_CONFIG_VERSION_D>();
//this.DoAddFormConfigVersion(formIds, pageTables, columns, pageTablePanels, otherCookies,formConfigVersions,
// formConfigVersionDetails);
//this.BantchAddEntity(formConfigVersions);
//this.BantchAddEntity(formConfigVersionDetails);
}
private void DoAddFormConfigVersion(List<Guid> formIds, List<T_PF_PAGE_TABLE> pageTables,
List<T_PF_COLUMN> columns, List<T_PF_PAGE_TABLE_PANEL> pageTablePanels,
Dictionary<Guid, List<string>> otherCookies,
List<T_PF_FORM_CONFIG_VERSION> formConfigVersions, List<T_PF_FORM_CONFIG_VERSION_D> formConfigVersionDetails)
{
//if (formIds == null || !formIds.Any()) return;
//var versionForms = this.GetEntities<T_PF_FORM>(t => formIds.Contains(t.ID), new BaseFilter()).ToList();
//var g= versionForms.GroupBy(t => t.ORG_ID.Value).ToList();
//foreach (var orgG in g)
//{
// var orgId = orgG.Key;
// List<string> cookies = new List<string>();
// var temps = orgG.ToList();
// temps.ForEach(t =>
// {
// cookies.Add(string.Format("form_config_form_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_custom_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_edit_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_tree_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_table_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_search_{0}_{1}", t.ID, orgId));
// cookies.Add(string.Format("form_config_search_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_chart_{0}_{1}", t.CODE, orgId));
// cookies.Add(string.Format("form_config_chart_{0}_{1}", t.ID, orgId));
// });
// if (pageTables != null && pageTables.Any())
// {
// var tempDestTables = pageTables.Where(t => t.ORG_ID == orgId).ToList();
// tempDestTables.ForEach(t =>
// {
// var tempForm = versionForms.FirstOrDefault(t1 => t1.ID == t.PAGE_FORM_ID);
// if (tempForm != null)
// {
// cookies.Add(string.Format("form_config_table_{0}_{1}_{2}", tempForm.CODE, orgId, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString())));
// cookies.Add(string.Format("form_config_table_{0}_{1}_{2}_{3}", tempForm.CODE, orgId, (t.PARENT_ID == null ? "" : t.PARENT_ID.ToString()),
// t.ID));
// }
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", t.ID, orgId));
// });
// }
// var tempDestColumnTableIds = columns==null?new List<Guid>(): columns.Where(t => t.ORG_ID == orgId).Select(t => t.PAGE_TABLE_ID.Value).ToList();
// if(pageTablePanels!=null)
// tempDestColumnTableIds.AddRange(pageTablePanels.Where(t => t.ORG_ID == orgId).Select(t => t.PAGE_TABLE_ID).ToList());
// tempDestColumnTableIds.ForEach(t =>
// {
// cookies.Add(string.Format("form_config_tablebase_{0}_{1}", t, orgId));
// });
// List<string> list = null;
// if (otherCookies!=null&&otherCookies.TryGetValue(orgId, out list))
// cookies.AddRange(list);
// if (!cookies.Any()) continue;
// decimal version = decimal.Zero;
// BaseFilter filter = new BaseFilter();
// filter.OrgId = orgId;
// filter.Order = DbOrder.DESC;
// filter.Sort = "VERSION";
// filter.OrgType = FilterOrgTypeEnum.仅本组织;
// var lastMaxVersion = this.GetOrderEntities<T_PF_FORM_CONFIG_VERSION>(null, filter).FirstOrDefault();
// if (lastMaxVersion != null)
// version = lastMaxVersion.VERSION;
// version += 1;
// T_PF_FORM_CONFIG_VERSION formConfigVersion = new T_PF_FORM_CONFIG_VERSION();
// formConfigVersion.ORG_ID = orgId;
// formConfigVersion.VERSION = version;
// formConfigVersions.Add(formConfigVersion);
// foreach (var cookieds in cookies)
// {
// T_PF_FORM_CONFIG_VERSION_D formConfigVersionDetail = new T_PF_FORM_CONFIG_VERSION_D();
// formConfigVersionDetail.ORG_ID = orgId;
// formConfigVersionDetail.REMOVE_COOKIE_KEY = cookieds;
// formConfigVersionDetail.FORM_CONFIG_VERSION_ID = formConfigVersion.ID;
// formConfigVersionDetails.Add(formConfigVersionDetail);
// }
//}
}
private void DoExcuteSqlAndGetResult(string sql, ExecuteSqlResult executeSqlResult,
ref int tableIndex)
{
if (string.IsNullOrEmpty(sql)) return;
sql = sql.Trim();
if (string.IsNullOrEmpty(sql)) return;
try
{
List<ExecuteSqlTable> tables = new List<ExecuteSqlTable>();
if (sql.IndexOf("Update", StringComparison.OrdinalIgnoreCase) > -1 ||
sql.IndexOf("Insert", StringComparison.OrdinalIgnoreCase) > -1 ||
sql.IndexOf("Delete", StringComparison.OrdinalIgnoreCase) > -1)
{
var ret = this.ExecuteNonQuery(System.Data.CommandType.Text, sql, null, null);
var executeSqlTable = new ExecuteSqlTable();
executeSqlTable.Label = "执行结果" + tableIndex;
executeSqlTable.Index = tableIndex;
tableIndex++;
ExecuteSqlColumn column = new ExecuteSqlColumn()
{
FieldName = "Result",
Label = "结果"
};
executeSqlTable.Columns.Add(column);
ExecuteSqlRowColumn executeSqlRowColumn = new ExecuteSqlRowColumn()
{
ColumnId = column.ID,
Value = ("影响" + ret + "行")
};
ExecuteSqlRow row = new ExecuteSqlRow();
row.Datas.Add(executeSqlRowColumn);
executeSqlTable.Rows.Add(row);
tables.Add(executeSqlTable);
}
else
{
var tempTableIndex = tableIndex;
this.ExecuteReader(sql, null, (reader) =>
{
do
{
ExecuteSqlTable executeSqlTable = null;
while (reader.Read())
{
if (executeSqlTable == null)
{
executeSqlTable = new ExecuteSqlTable();
executeSqlTable.IsSelectTable = true;
executeSqlTable.Label = "执行结果" + tempTableIndex;
executeSqlTable.Index = tempTableIndex;
tempTableIndex++;
for (int i = 0; i < reader.FieldCount; i++)
{
ExecuteSqlColumn column = new ExecuteSqlColumn()
{
FieldName = reader.GetName(i),
Label = reader.GetName(i),
ColumnType = reader.GetFieldType(i),
};
executeSqlTable.Columns.Add(column);
}
tables.Add(executeSqlTable);
}
ExecuteSqlRow row = new ExecuteSqlRow();
int j = 0;
foreach (var item in executeSqlTable.Columns)
{
ExecuteSqlRowColumn executeSqlRowColumn = new ExecuteSqlRowColumn()
{
ColumnId = item.ID,
};
var obj = reader.GetValue(j);
if (obj != null && obj != DBNull.Value)
{
if (obj is byte[])
{
var blob = obj as byte[];
executeSqlRowColumn.Value = BitConverter.ToString(blob).Replace("-", "");
}
else
{
executeSqlRowColumn.Value = Convert.ToString(obj);
}
}
row.Datas.Add(executeSqlRowColumn);
j++;
}
executeSqlTable.Rows.Add(row);
}
}
while (reader.NextResult());
});
tableIndex = tempTableIndex;
}
if (tables.Any())
executeSqlResult.Tables.AddRange(tables);
}
catch (Exception ex)
{
var executeSqlTable = new ExecuteSqlTable();
executeSqlTable.Label = "执行结果" + tableIndex;
executeSqlTable.Index = tableIndex;
tableIndex++;
ExecuteSqlColumn column = new ExecuteSqlColumn()
{
FieldName = "Result",
Label = "执行错误"
};
executeSqlTable.Columns.Add(column);
ExecuteSqlRowColumn executeSqlRowColumn = new ExecuteSqlRowColumn()
{
ColumnId = column.ID,
Value = ("执行语法错误:" + ex.Message)
};
ExecuteSqlRow row = new ExecuteSqlRow();
row.Datas.Add(executeSqlRowColumn);
executeSqlTable.Rows.Add(row);
executeSqlResult.Tables.Add(executeSqlTable);
}
}
public void GetEntitisSql<T>(DataBaseType dataBaseType, Guid orgId, List<string> result, string dstOrgId, int sqlType) where T : MesEntityBase, new()
{
var filiterThisDep = new BaseFilter(orgId, FilterOrgTypeEnum.);
filiterThisDep.IgnoreDataRule = true;
var list = this.GetEntities<T>(null, filiterThisDep).ToList();
if (list != null && list.Any())
{
foreach (var item in list)
this.DoGetSqlByEntity(dataBaseType, item, result, dstOrgId, sqlType);
}
}
public PFModuleTypeEnum GetModelTypeByName(string tableName)
{
var newName = tableName.ToLower();
var newNameAry = newName.Split(new char[] { '_' });
string moduleName = string.Empty;
if (newNameAry.Any() && newNameAry.Length >= 2)
moduleName = newNameAry[1].ToUpper();
if (string.IsNullOrEmpty(moduleName)) return PFModuleTypeEnum.;
foreach (var item in Enum.GetValues(typeof(PFModuleTypeEnum)))
{
var attrs = item.GetType().GetField(item.ToString()).GetCustomAttributes(typeof(DescriptionAttribute), true);
if (attrs != null && attrs.Length > 0)
{
DescriptionAttribute descAttr = attrs[0] as DescriptionAttribute;
if (string.Compare(descAttr.Description, moduleName, true) == 0)
return (PFModuleTypeEnum)item;
}
}
return PFModuleTypeEnum.;
}
}
}