2841 lines
152 KiB
C#
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.平台管理;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
}
|