You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2577 lines
91 KiB
Plaintext

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

using System;
using System.Data;
using System.Collections;
using BP.DA;
using BP.Sys.Base;
using BP.En;
using System.Collections.Generic;
using System.IO;
using BP.Pub;
using BP.Web;
namespace BP.Sys
{
/// <summary>
/// 映射基础
/// </summary>
public class MapDataAttr : EntityNoNameAttr
{
/// <summary>
/// 表单事件实体类
/// </summary>
public const string FormEventEntity = "FormEventEntity";
/// <summary>
/// 存储表
/// </summary>
public const string PTable = "PTable";
/// <summary>
/// 表存储格式0=自定义表,1=指定表,可以修改字段2=执行表不可以修改字段.
/// </summary>
public const string PTableModel = "PTableModel";
/// <summary>
/// 从表数量
/// </summary>
public const string Dtls = "Dtls";
/// <summary>
/// 实体主键
/// </summary>
public const string EnPK = "EnPK";
/// <summary>
/// 宽度
/// </summary>
public const string FrmW = "FrmW";
/// <summary>
/// 表格列(对傻瓜表单有效)
/// </summary>
public const string TableCol = "TableCol";
/// <summary>
/// 来源
/// </summary>
public const string FrmFrom = "FrmFrom";
/// <summary>
/// 设计者
/// </summary>
public const string Designer = "Designer";
/// <summary>
/// 设计者单位
/// </summary>
public const string DesignerUnit = "DesignerUnit";
/// <summary>
/// 设计者联系方式
/// </summary>
public const string DesignerContact = "DesignerContact";
/// <summary>
/// 设计器
/// </summary>
public const string DesignerTool11 = "DesignerTool";
/// <summary>
/// 表单树类别
/// </summary>
public const string FK_FormTree = "FK_FormTree";
/// <summary>
/// 表单类型
/// </summary>
public const string FrmType = "FrmType";
/// <summary>
/// 业务类型
/// </summary>
public const string EntityType = "EntityType";
/// <summary>
/// 表单展示方式
/// </summary>
public const string FrmShowType = "FrmShowType";
/// <summary>
/// 单据模板
/// </summary>
public const string FrmModel = "FrmModel";
/// <summary>
/// Url(对于嵌入式表单有效)
/// </summary>
public const string UrlExt = "UrlExt";
/// <summary>
/// Tag
/// </summary>
public const string Tag = "Tag";
/// <summary>
/// 备注
/// </summary>
public const string Note = "Note";
/// <summary>
/// Idx
/// </summary>
public const string Idx = "Idx";
/// <summary>
/// GUID
/// </summary>
public const string GUID = "GUID";
/// <summary>
/// 版本号
/// </summary>
public const string Ver = "Ver";
/// <summary>
/// 应用类型
/// </summary>
public const string AppType = "AppType";
/// <summary>
/// 表单body属性.
/// </summary>
public const string BodyAttr = "BodyAttr";
/// <summary>
/// 流程控件
/// </summary>
public const string FlowCtrls = "FlowCtrls";
/// <summary>
///组织结构.
/// </summary>
public const string OrgNo = "OrgNo";
/// <summary>
/// Icon.
/// </summary>
public const string Icon = "Icon";
#region DBList类型的实体.
/// <summary>
/// 数据源
/// </summary>
public const string DBSrc = "DBSrc";
/// <summary>
/// 数据源类型
/// </summary>
public const string DBType = "DBType";
/// <summary>
/// 单行
/// </summary>
public const string ExpEn = "ExpEn";
/// <summary>
/// 列表
/// </summary>
public const string ExpList = "ExpList";
/// <summary>
/// 表达式
/// </summary>
public const string ExpCount = "ExpCount";
/// <summary>
/// 分页的模式
/// </summary>
public const string ExpListPageModel = "ExpListPageModel";
#endregion DBList类型的实体.
#region 报表属性(参数的方式存储).
/// <summary>
/// 是否关键字查询
/// </summary>
public const string IsSearchKey = "IsSearchKey";
/// <summary>
/// 时间段查询方式
/// </summary>
public const string DTSearchWay = "DTSearchWay";
/// <summary>
/// 时间字段
/// </summary>
public const string DTSearchKey = "DTSearchKey";
/// <summary>
/// 查询外键枚举字段
/// </summary>
public const string RptSearchKeys = "RptSearchKeys";
#endregion 报表属性(参数的方式存储).
#region 其他计算属性,参数存储.
/// <summary>
/// 最左边的值
/// </summary>
public const string MaxLeft = "MaxLeft";
/// <summary>
/// 最右边的值
/// </summary>
public const string MaxRight = "MaxRight";
/// <summary>
/// 最头部的值
/// </summary>
public const string MaxTop = "MaxTop";
/// <summary>
/// 最底部的值
/// </summary>
public const string MaxEnd = "MaxEnd";
#endregion 其他计算属性,参数存储.
#region 参数属性.
public const string EnsName = "EnsName";
/// <summary>
/// 是否是加密
/// </summary>
public const string IsJM = "IsJM";
#endregion 参数属性.
}
/// <summary>
/// 映射基础
/// </summary>
public class MapData : EntityNoName
{
#region entity 相关属性(参数属性)
/// <summary>
/// 属性ens
/// </summary>
public string EnsName
{
get
{
return this.GetValStringByKey(MapDataAttr.EnsName);
}
set
{
this.SetPara(MapDataAttr.EnsName, value);
}
}
/// <summary>
/// 是不是加密,为铁路局增加.
/// </summary>
public bool ItIsJM
{
get
{
return this.GetParaBoolen(MapDataAttr.IsJM);
}
set
{
this.SetPara(MapDataAttr.IsJM, value);
}
}
#endregion entity 相关操作.
#region 报表属性(参数方式存储).
/// <summary>
/// 是否关键字查询
/// </summary>
public bool ItIsSearchKey
{
get
{
return this.GetParaBoolen(MapDataAttr.IsSearchKey, true);
}
set
{
this.SetPara(MapDataAttr.IsSearchKey, value);
}
}
/// <summary>
/// 时间段查询方式
/// </summary>
public DTSearchWay DTSearchWay
{
get
{
return (DTSearchWay)this.GetParaInt(MapDataAttr.DTSearchWay);
}
set
{
this.SetPara(MapDataAttr.DTSearchWay, (int)value);
}
}
/// <summary>
/// 查询外键枚举字段
/// </summary>
public string RptSearchKeys
{
get
{
return this.GetParaString(MapDataAttr.RptSearchKeys, "*");
}
set
{
this.SetPara(MapDataAttr.RptSearchKeys, value);
}
}
/// <summary>
/// 查询key.
/// </summary>
public string DTSearchKey
{
get
{
return this.GetParaString(MapDataAttr.DTSearchKey);
}
set
{
this.SetPara(MapDataAttr.DTSearchKey, value);
}
}
#endregion 报表属性(参数方式存储).
#region 外键属性
/// <summary>
/// 版本号
/// </summary>
public int Ver2022
{
get
{
return this.GetParaInt(MapDataAttr.Ver, 1);
}
set
{
this.SetPara(MapDataAttr.Ver, value);
}
}
public string OrgNo
{
get
{
return this.GetValStringByKey(MapDataAttr.OrgNo);
}
set
{
this.SetValByKey(MapDataAttr.OrgNo, value);
}
}
/// <summary>
/// 顺序号
/// </summary>
public int Idx
{
get
{
return this.GetValIntByKey(MapDataAttr.Idx);
}
set
{
this.SetValByKey(MapDataAttr.Idx, value);
}
}
/// <summary>
/// 框架
/// </summary>
public MapFrames MapFrames
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new MapFrames(),
MapExtAttr.FK_MapData, this.No);
return ens as MapFrames;
}
}
/// <summary>
/// 分组字段
/// </summary>
public GroupFields GroupFields
{
get
{
GroupFields obj = this.GetRefObject("GroupFields") as GroupFields;
if (obj == null)
{
obj = new GroupFields(this.No);
this.SetRefObject("GroupFields", obj);
}
return obj;
}
}
/// <summary>
/// 逻辑扩展
/// </summary>
public MapExts MapExts
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new MapExts(),
MapExtAttr.FK_MapData, this.No);
return ens as MapExts;
//MapExts obj = this.GetRefObject("MapExts") as MapExts;
//if (obj == null)
//{
// obj = new MapExts(this.No);
// this.SetRefObject("MapExts", obj);
//}
//return obj;
}
}
/// <summary>
/// 事件:
/// 1.该事件与Node,Flow,MapDtl,MapData一样的算法.
/// 2.如果一个业务逻辑有变化,其他的也要变化.
/// </summary>
public FrmEvents FrmEvents
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new FrmEvents(),
FrmEventAttr.FrmID, this.No);
return ens as FrmEvents;
}
}
/// <summary>
/// 从表原始属性的获取
/// </summary>
public MapDtls OrigMapDtls
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new MapDtls(),
MapDtlAttr.FK_MapData, this.No, MapDtlAttr.FK_Node, 0);
return ens as MapDtls;
}
}
/// <summary>
/// 查询给MapData下的所有从表数据
/// </summary>
public MapDtls MapDtls
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new MapDtls(),
MapDtlAttr.FK_MapData, this.No);
return ens as MapDtls;
//MapDtls obj = this.GetRefObject("MapDtls") as MapDtls;
//if (obj == null)
//{
// obj = new MapDtls(this.No);
// this.SetRefObject("MapDtls", obj);
//}
//return obj;
}
}
/// <summary>
/// 枚举值
/// </summary>
public SysEnums SysEnums
{
get
{
SysEnums obj = this.GetRefObject("SysEnums") as SysEnums;
obj = null;
if (obj == null)
{
obj = new SysEnums();
if (BP.Difference.SystemConfig.AppCenterDBType == DBType.MySQL)
{
string strs = "";
Paras ps = new Paras();
ps.SQL = "SELECT UIBindKey FROM Sys_MapAttr WHERE FK_MapData=" + ps.DBStr + "FK_MapData AND LGType=1";
ps.Add("FK_MapData", this.No);
DataTable dt = DBAccess.RunSQLReturnTable(ps);
foreach (DataRow dr in dt.Rows)
{
strs += "'" + dr[0].ToString() + "',";
}
if (dt.Rows.Count >= 1)
{
strs += "'ssss'";
obj.RetrieveInOrderBy("EnumKey", strs, SysEnumAttr.IntKey);
}
}
else
{
if (BP.Difference.SystemConfig.CCBPMRunModel == CCBPMRunModel.SAAS)
{
string enumKeySQL = "SELECT UIBindKey FROM Sys_MapAttr WHERE FK_MapData = '" + this.No + "' AND LGType = 1 ";
string sqlWhere = " EnumKey IN (" + enumKeySQL + ") AND OrgNo='" + BP.Web.WebUser.OrgNo + "'";
string sqlEnum = "SELECT * FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE " + sqlWhere;
sqlEnum += " UNION ";
sqlEnum += "SELECT * FROM " + BP.Sys.Base.Glo.SysEnum() + " WHERE EnumKey IN (" + enumKeySQL + ") AND EnumKey NOT IN (SELECT EnumKey FROM Sys_Enum WHERE " + sqlWhere + ") AND (OrgNo Is Null Or OrgNo='')";
sqlEnum += "Order By IntKey";
DataTable dt = DBAccess.RunSQLReturnTable(sqlEnum);
QueryObject.InitEntitiesByDataTable(obj, dt, null);
}
else
{
obj.RetrieveInSQL(SysEnumAttr.EnumKey, "SELECT UIBindKey FROM Sys_MapAttr WHERE FK_MapData='" + this.No + "' AND LGType=1 ", SysEnumAttr.IntKey);
}
}
this.SetRefObject("SysEnums", obj);
}
return obj;
}
}
/// <summary>
/// 图片
/// </summary>
public FrmImgs FrmImgs
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new FrmImgs(),
FrmImgAttr.FrmID, this.No);
return ens as FrmImgs;
}
}
/// <summary>
/// 附件
/// </summary>
public FrmAttachments FrmAttachments
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new FrmAttachments(),
FrmAttachmentAttr.FK_MapData, this.No);
return ens as FrmAttachments;
}
}
/// <summary>
/// 附件模板列表
/// </summary>
// public SysFileManagers sysFileManagers
// {
// get
// {
// var ens = this.GetEntitiesAttrFromAutoNumCache(new SysFileManagers(),
//SysFileManagerAttr.FrmID, this.No);
// return ens as SysFileManagers;
// }
// }
/// <summary>
/// 图片附件
/// </summary>
public FrmImgAths FrmImgAths
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new FrmImgAths(),
FrmImgAthAttr.FrmID, this.No);
return ens as FrmImgAths;
}
}
/// <summary>
/// 单选按钮
/// </summary>
public FrmRBs FrmRBs
{
get
{
Entities ens = this.GetEntitiesAttrFromAutoNumCache(new FrmRBs(),
FrmRBAttr.FrmID, this.No);
return ens as FrmRBs;
}
}
/// <summary>
/// 属性
/// </summary>
public MapAttrs MapAttrs
{
get
{
MapAttrs obj = this.GetRefObject("MapAttrs") as MapAttrs;
if (obj == null)
{
obj = new MapAttrs(this.No);
this.SetRefObject("MapAttrs", obj);
}
return obj;
}
}
#endregion
#region 缓存方法.
public void CleanObject()
{
this.Row.SetValByKey("FrmEles", null);
this.Row.SetValByKey("MapFrames", null);
this.Row.SetValByKey("GroupFields", null);
this.Row.SetValByKey("MapExts", null);
this.Row.SetValByKey("FrmEvents", null);
this.Row.SetValByKey("MapDtls", null);
this.Row.SetValByKey("SysEnums", null);
this.Row.SetValByKey("FrmRpts", null);
this.Row.SetValByKey("FrmLinks", null);
this.Row.SetValByKey("FrmBtns", null);
this.Row.SetValByKey("FrmEles", null);
// this.Row.SetValByKey("FrmLines", null);
// this.Row.SetValByKey("FrmLabs", null);
this.Row.SetValByKey("FrmAttachments", null);
this.Row.SetValByKey("FrmImgAthDBs", null);
this.Row.SetValByKey("FrmRBs", null);
this.Row.SetValByKey("MapAttrs", null);
return;
}
/// <summary>
/// 清空缓存
/// </summary>
public string ClearCache()
{
CacheFrmTemplate.Remove(this.No);
Cache.SetMap(this.No, null);
CleanObject();
Cache.SQL_Cache.Remove(this.No);
return "执行成功.";
}
#endregion 缓存方法.
#region 基本属性.
/// <summary>
/// 事件实体
/// </summary>
public string FormEventEntity
{
get
{
return this.GetValStringByKey(MapDataAttr.FormEventEntity);
}
set
{
this.SetValByKey(MapDataAttr.FormEventEntity, value);
}
}
public static Boolean IsEditDtlModel
{
get
{
string s = BP.Web.WebUser.GetSessionByKey("IsEditDtlModel", "0");
if (s == "0")
return false;
else
return true;
}
set
{
BP.Web.WebUser.SetSessionByKey("IsEditDtlModel", "1");
}
}
public string ICON
{
get
{
return this.GetValStringByKey(MapDataAttr.Icon);
}
}
#endregion 基本属性.
#region 属性
/// <summary>
/// 物理表
/// </summary>
public string PTable
{
get
{
string s = this.GetValStrByKey(MapDataAttr.PTable);
if (DataType.IsNullOrEmpty(s) == true)
return this.No;
return s.Trim();
}
set
{
this.SetValByKey(MapDataAttr.PTable, value);
}
}
/// <summary>
/// 表存储模式0=自定义表,1,指定的表,2=指定的表不能修改表结构.
/// @周朋
/// </summary>
public int PTableModel
{
get
{
return this.GetValIntByKey(MapDataAttr.PTableModel);
}
set
{
this.SetValByKey(MapDataAttr.PTableModel, value);
}
}
/// <summary>
/// URL
/// </summary>
public string UrlExt
{
get
{
return this.GetValStrByKey(MapDataAttr.UrlExt);
}
set
{
this.SetValByKey(MapDataAttr.UrlExt, value);
}
}
public DBUrlType HisDBUrl
{
get
{
return DBUrlType.AppCenterDSN;
// return (DBUrlType)this.GetValIntByKey(MapDataAttr.DBURL);
}
}
public int HisFrmTypeInt
{
get
{
return this.GetValIntByKey(MapDataAttr.FrmType);
}
set
{
this.SetValByKey(MapDataAttr.FrmType, value);
}
}
public FrmType HisFrmType
{
get
{
return (FrmType)this.GetValIntByKey(MapDataAttr.FrmType);
}
set
{
this.SetValByKey(MapDataAttr.FrmType, (int)value);
}
}
public int HisEntityType
{
get
{
return this.GetValIntByKey(MapDataAttr.EntityType);
}
set
{
this.SetValByKey(MapDataAttr.EntityType, value);
}
}
/// <summary>
/// 表单类型名称
/// </summary>
public string HisFrmTypeText
{
get
{
return this.HisFrmType.ToString();
// SysEnum se = new SysEnum("FrmType", this.HisFrmTypeInt);
// return se.Lab;
}
}
/// <summary>
/// 备注
/// </summary>
public string Note
{
get
{
return this.GetValStrByKey(MapDataAttr.Note);
}
set
{
this.SetValByKey(MapDataAttr.Note, value);
}
}
/// <summary>
/// 是否有CA.
/// </summary>
public bool ItIsHaveCA
{
get
{
return this.GetParaBoolen("IsHaveCA", false);
}
set
{
this.SetPara("IsHaveCA", value);
}
}
/// <summary>
///是否启用装载填充
/// </summary>
public bool ItIsPageLoadFull
{
get
{
return this.GetParaBoolen("IsPageLoadFull", false);
}
set
{
this.SetPara("IsPageLoadFull", value);
}
}
/// <summary>
/// 数据源
/// </summary>
public string DBSrc
{
get
{
return this.GetValStrByKey(MapDataAttr.DBSrc);
}
set
{
this.SetValByKey(MapDataAttr.DBSrc, value);
}
}
/// <summary>
/// 类别,可以为空.
/// </summary>
public string FormTreeNo
{
get
{
return this.GetValStrByKey(MapDataAttr.FK_FormTree);
}
set
{
this.SetValByKey(MapDataAttr.FK_FormTree, value);
}
}
/// <summary>
/// 类别名称
/// </summary>
public string FormTreeText
{
get
{
return DBAccess.RunSQLReturnStringIsNull("SELECT Name FROM Sys_FormTree WHERE No='" + this.FormTreeNo + "'", "目录错误");
}
}
/// <summary>
/// 从表集合.
/// </summary>
public string Dtls
{
get
{
return this.GetValStrByKey(MapDataAttr.Dtls);
}
set
{
this.SetValByKey(MapDataAttr.Dtls, value);
}
}
/// <summary>
/// 主键
/// </summary>
public string EnPK
{
get
{
string s = this.GetValStrByKey(MapDataAttr.EnPK);
if (DataType.IsNullOrEmpty(s))
return "OID";
return s;
}
set
{
this.SetValByKey(MapDataAttr.EnPK, value);
}
}
private Entities _HisEns = null;
public new Entities HisEns
{
get
{
if (_HisEns == null)
{
_HisEns = BP.En.ClassFactory.GetEns(this.No);
}
return _HisEns;
}
}
public Entity HisEn
{
get
{
return this.HisEns.GetNewEntity;
}
}
public float FrmW
{
get
{
return this.GetValFloatByKey(MapDataAttr.FrmW);
}
set
{
this.SetValByKey(MapDataAttr.FrmW, value);
}
}
/// <summary>
/// 应用类型. 0独立表单.1节点表单
/// </summary>
public string AppType
{
get
{
return this.GetValStrByKey(MapDataAttr.AppType);
}
set
{
this.SetValByKey(MapDataAttr.AppType, value);
}
}
/// <summary>
/// 表单body属性.
/// </summary>
public string BodyAttr
{
get
{
string str = this.GetValStrByKey(MapDataAttr.BodyAttr);
str = str.Replace("~", "'");
return str;
}
set
{
this.SetValByKey(MapDataAttr.BodyAttr, value);
}
}
/// <summary>
/// 流程控件s.
/// </summary>
public string FlowCtrls
{
get
{
return this.GetValStrByKey(MapDataAttr.FlowCtrls);
}
set
{
this.SetValByKey(MapDataAttr.FlowCtrls, value);
}
}
public int TableCol
{
get
{
return this.GetValIntByKey(MapDataAttr.TableCol);
}
set
{
this.SetValByKey(MapDataAttr.TableCol, value);
}
}
/// <summary>
/// 实体表单类型.@0=独立表单@1=单据@2=编号名称实体@3=树结构实体
/// </summary>
public EntityType EntityType
{
get
{
return (EntityType)this.GetValIntByKey(MapDataAttr.EntityType);
}
set
{
this.SetValByKey(MapDataAttr.EntityType, (int)value);
}
}
#endregion
#region 构造方法
public Map GenerHisMap()
{
MapAttrs mapAttrs = this.MapAttrs;
if (mapAttrs.Count == 0)
{
this.RepairMap();
mapAttrs = this.MapAttrs;
}
Map map = new Map(this.PTable, this.Name);
Attrs attrs = new Attrs();
foreach (MapAttr mapAttr in mapAttrs)
map.AddAttr(mapAttr.HisAttr);
// 产生从表。
MapDtls dtls = this.MapDtls; // new MapDtls(this.No);
foreach (MapDtl dtl in dtls)
{
GEDtls dtls1 = new GEDtls(dtl.No);
map.AddDtl(dtls1, "RefPK");
}
#region 查询条件.
map.ItIsShowSearchKey = this.ItIsSearchKey; //是否启用关键字查询.
// 按日期查询.
map.DTSearchWay = this.DTSearchWay; //日期查询方式.
map.DTSearchKey = this.DTSearchKey; //日期字段.
//是否是加密
map.ItIsJM = this.ItIsJM;
//加入外键查询字段.
string[] keys = this.RptSearchKeys.Split('*');
foreach (string key in keys)
{
if (DataType.IsNullOrEmpty(key))
continue;
if (map.Attrs.Contains(key) == false)
continue;
map.AddSearchAttr(key);
}
#endregion 查询条件.
return map;
}
private GEEntity _HisEn = null;
public GEEntity HisGEEn
{
get
{
if (this._HisEn == null)
_HisEn = new GEEntity(this.No);
return _HisEn;
}
}
/// <summary>
/// 生成实体
/// </summary>
/// <param name="ds"></param>
/// <returns></returns>
public GEEntity GenerGEEntityByDataSet(DataSet ds)
{
// New 它的实例.
GEEntity en = this.HisGEEn;
// 它的table.
DataTable dt = ds.Tables[this.No];
//装载数据.
en.Row.LoadDataTable(dt, dt.Rows[0]);
// dtls.
MapDtls dtls = this.MapDtls;
foreach (MapDtl item in dtls)
{
DataTable dtDtls = ds.Tables[item.No];
GEDtls dtlsEn = new GEDtls(item.No);
foreach (DataRow dr in dtDtls.Rows)
{
// 产生它的Entity data.
GEDtl dtl = (GEDtl)dtlsEn.GetNewEntity;
dtl.Row.LoadDataTable(dtDtls, dr);
//加入这个集合.
dtlsEn.AddEntity(dtl);
}
//加入到他的集合里.
en.Dtls.Add(dtDtls);
}
return en;
}
/// <summary>
/// 生成map.
/// </summary>
/// <param name="no"></param>
/// <returns></returns>
public static Map GenerHisMap(string no)
{
if (BP.Difference.SystemConfig.isDebug)
{
MapData md = new MapData();
md.No = no;
md.Retrieve();
return md.GenerHisMap();
}
else
{
Map map = Cache.GetMap(no);
if (map == null)
{
MapData md = new MapData();
md.No = no;
md.Retrieve();
map = md.GenerHisMap();
Cache.SetMap(no, map);
}
return map;
}
}
/// <summary>
/// 映射基础
/// </summary>
public MapData()
{
}
/// <summary>
/// 映射基础
/// </summary>
/// <param name="no">映射编号</param>
public MapData(string no)
{
this.No = no;
this.Retrieve();
}
/// <summary>
/// EnMap
/// </summary>
public override Map EnMap
{
get
{
if (this._enMap != null)
return this._enMap;
Map map = new Map("Sys_MapData", "表单注册表");
#region 基础信息.
map.AddTBStringPK(MapDataAttr.No, null, "编号", true, false, 1, 200, 100);
map.AddTBString(MapDataAttr.Name, null, "描述", true, false, 0, 500, 20);
map.AddTBString(MapDataAttr.FormEventEntity, null, "事件实体", true, true, 0, 100, 20, true);
map.AddTBString(MapDataAttr.EnPK, null, "实体主键", true, false, 0, 200, 20);
map.AddTBString(MapDataAttr.PTable, null, "物理表", true, false, 0, 500, 20);
//@周朋 表存储格式0=自定义表,1=指定表,可以修改字段2=执行表不可以修改字段.
map.AddTBInt(MapDataAttr.PTableModel, 0, "表存储模式", true, true);
map.AddTBString(MapDataAttr.UrlExt, null, "连接(对嵌入式表单有效)", true, false, 0, 500, 20);
map.AddTBString(MapDataAttr.Dtls, null, "从表", true, false, 0, 500, 20);
//格式为: @1=方案名称1@2=方案名称2@3=方案名称3
//map.AddTBString(MapDataAttr.Slns, null, "表单控制解决方案", true, false, 0, 500, 20);
map.AddTBInt(MapDataAttr.FrmW, 900, "FrmW", true, true);
// @0=4列, @1=6 列.
map.AddTBInt(MapDataAttr.TableCol, 0, "傻瓜表单显示的列", true, true);
//Tag
map.AddTBString(MapDataAttr.Tag, null, "Tag", true, false, 0, 500, 20);
// 可以为空这个字段。
//map.AddTBString(MapDataAttr.FK_FrmSort, null, "表单类别", true, false, 0, 500, 20);
map.AddTBString(MapDataAttr.FK_FormTree, null, "表单树类别", true, false, 0, 500, 20);
// enumFrmType @自由表单,@傻瓜表单,@嵌入式表单.
map.AddDDLSysEnum(MapDataAttr.FrmType, (int)BP.Sys.FrmType.FoolForm, "表单类型", true, false, MapDataAttr.FrmType);
map.AddTBInt(MapDataAttr.FrmShowType, 0, "表单展示方式", true, true);
map.AddDDLSysEnum(MapDataAttr.EntityType, 0, "业务类型", true, false, MapDataAttr.EntityType,
"@0=独立表单@1=单据@2=编号名称实体@3=树结构实体");
map.SetHelperAlert(MapDataAttr.EntityType, "该实体的类型,@0=单据@1=编号名称实体@2=树结构实体.");
map.AddBoolean("IsEnableJs", false, "是否启用自定义js函数", true, true, true);
// 应用类型. 0独立表单.1节点表单
map.AddTBInt(MapDataAttr.AppType, 0, "应用类型", true, false);
map.AddTBString(MapDataAttr.DBSrc, "local", "数据源", true, false, 0, 100, 20);
map.AddTBString(MapDataAttr.BodyAttr, null, "表单Body属性", true, false, 0, 100, 20);
#endregion 基础信息.
#region 设计者信息.
map.AddTBString(MapDataAttr.Note, null, "备注", true, false, 0, 500, 20);
map.AddTBString(MapDataAttr.Designer, null, "设计者", true, false, 0, 500, 20);
map.AddTBString(MapDataAttr.DesignerUnit, null, "单位", true, false, 0, 500, 20);
map.AddTBString(MapDataAttr.DesignerContact, null, "联系方式", true, false, 0, 500, 20);
map.AddTBInt(MapDataAttr.Idx, 100, "顺序号", true, true);
map.AddTBString(MapDataAttr.GUID, null, "GUID", true, false, 0, 128, 20);
map.AddTBString(MapDataAttr.Ver, null, "版本号", true, false, 0, 30, 20);
map.AddTBString(MapDataAttr.Icon, null, "Icon", true, false, 0, 100, 20, true);
//流程控件.
map.AddTBString(MapDataAttr.FlowCtrls, null, "流程控件", true, true, 0, 200, 20);
//增加参数字段.
map.AddTBAtParas(4000);
#endregion
map.AddTBString(MapDataAttr.OrgNo, null, "OrgNo", true, false, 0, 50, 20);
this._enMap = map;
return this._enMap;
}
}
/// <summary>
/// 执行复制.
/// </summary>
/// <param name="copyToFrmID"></param>
/// <param name="frmName"></param>
/// <returns></returns>
public string DoCopy(string copyToFrmID, string frmName)
{
BP.Sys.CCFormAPI.CopyFrm(this.No, copyToFrmID, frmName, this.FormTreeNo);
return "执行成功";
}
/// <summary>
/// 上移
/// </summary>
public void DoUp()
{
this.DoOrderUp(MapDataAttr.FK_FormTree, this.FormTreeNo, MapDataAttr.Idx);
}
/// <summary>
/// 下移
/// </summary>
public void DoOrderDown()
{
this.DoOrderDown(MapDataAttr.FK_FormTree, this.FormTreeNo, MapDataAttr.Idx);
}
//检查表单
public void CheckPTableSaveModel(string filed)
{
if (this.PTableModel == 2)
{
/*如果是存储格式*/
if (DBAccess.IsExitsTableCol(this.PTable, filed) == false)
throw new Exception("@表单的表存储模式不允许您创建不存在的字段(" + filed + "),不允许修改表结构.");
}
}
/// <summary>
/// 获得PTableModel=2模式下的表单没有被使用的字段集合.
/// </summary>
/// <param name="frmID"></param>
/// <returns></returns>
public static DataTable GetFieldsOfPTableMode2(string frmID)
{
string pTable = "";
MapDtl dtl = new MapDtl();
dtl.No = frmID;
if (dtl.RetrieveFromDBSources() == 1)
{
pTable = dtl.PTable;
}
else
{
MapData md = new MapData();
md.No = frmID;
md.RetrieveFromDBSources();
pTable = md.PTable;
}
//获得原始数据.
DataTable dt = DBAccess.GetTableSchema(pTable);
//创建样本表结构.
DataTable mydt = DBAccess.GetTableSchema(pTable);
mydt.Rows.Clear();
//获得现有的列..
MapAttrs attrs = new MapAttrs(frmID);
string flowFiels = ",GUID,PRI,PrjNo,PrjName,PEmp,AtPara,FlowNote,WFSta,PNodeID,FK_FlowSort,FK_Flow,OID,FID,Title,WFState,CDT,FlowStarter,FlowStartRDT,FK_Dept,FK_NY,FlowDaySpan,FlowEmps,FlowEnder,FlowEnderRDT,FlowEndNode,MyNum,PWorkID,PFlowNo,BillNo,ProjNo,";
//排除已经存在的列. 把所有的列都输出给前台,让前台根据类型分拣.
foreach (DataRow dr in dt.Rows)
{
string key = dr["FName"].ToString();
if (attrs.Contains(MapAttrAttr.KeyOfEn, key) == true)
continue;
if (flowFiels.Contains("," + key + ",") == true)
continue;
DataRow mydr = mydt.NewRow();
mydr["FName"] = dr["FName"];
mydr["FType"] = dr["FType"];
mydr["FLen"] = dr["FLen"];
mydr["FDesc"] = dr["FDesc"];
mydt.Rows.Add(mydr);
}
return mydt;
}
#endregion
#region 常用方法.
private FormEventBase _HisFEB = null;
public FormEventBase HisFEB
{
get
{
if (this.FormEventEntity == "")
return null;
if (_HisFEB == null)
_HisFEB = BP.Sys.Base.Glo.GetFormEventBaseByEnName(this.No);
return _HisFEB;
}
}
/// <summary>
/// 升级逻辑.
/// </summary>
public void Upgrade()
{
string sql = "";
#region 升级ccform控件.
//if (DBAccess.IsExitsObject("Sys_FrmLine") == true)
//{
// //重命名.
// BP.Sys.SFDBSrc dbsrc = new SFDBSrc("local");
// dbsrc.Rename("Table", "Sys_FrmLine", "Sys_FrmLineBak");
//}
if (DBAccess.IsExitsObject("Sys_FrmLab") == true)
{
//重命名.
BP.Sys.SFDBSrc dbsrc = new SFDBSrc("local");
dbsrc.Rename("Table", "Sys_FrmLab", "Sys_FrmLabBak");
}
if (DBAccess.IsExitsObject("Sys_FrmBtn") == true)
{
//重命名.
BP.Sys.SFDBSrc dbsrc = new SFDBSrc("local");
dbsrc.Rename("Table", "Sys_FrmLab", "Sys_FrmLabBak");
}
#endregion 升级ccform控件.
}
/// <summary>
/// 导入数据
/// </summary>
/// <param name="ds"></param>
/// <returns></returns>
public static MapData ImpMapData(DataSet ds)
{
string errMsg = "";
if (ds.Tables.Contains("WF_Flow") == true)
errMsg += "@此模板文件为流程模板。";
if (ds.Tables.Contains("Sys_MapAttr") == false)
errMsg += "@缺少表:Sys_MapAttr";
if (ds.Tables.Contains("Sys_MapData") == false)
errMsg += "@缺少表:Sys_MapData";
if (errMsg != "")
throw new Exception(errMsg);
DataTable dt = ds.Tables["Sys_MapData"];
string fk_mapData = dt.Rows[0]["No"].ToString();
MapData md = new MapData();
md.No = fk_mapData;
if (md.IsExits)
throw new Exception("err@已经存在(" + fk_mapData + ")的表单ID所以您不能导入。");
//执行删除操作. 导入时为什么要执行删除?本来就没有这个表单,删除肯定报错,先注释了
//md.Delete();
//导入.
return ImpMapData(fk_mapData, ds);
}
/// <summary>
/// 设置表单为只读属性
/// </summary>
/// <param name="fk_mapdata">表单ID</param>
public static void SetFrmIsReadonly(string fk_mapdata)
{
//把主表字段设置为只读.
MapAttrs attrs = new MapAttrs(fk_mapdata);
foreach (MapAttr attr in attrs)
{
if (attr.DefValReal.Contains("@"))
{
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.setDefValReal(""); //清空默认值.
attr.SetValByKey("ExtDefVal", ""); //设置默认值.
attr.Update();
continue;
}
if (attr.UIIsEnable == true)
{
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.Update();
continue;
}
}
//把从表字段设置为只读.
MapDtls dtls = new MapDtls(fk_mapdata);
foreach (MapDtl dtl in dtls)
{
dtl.ItIsInsert = false;
dtl.ItIsUpdate = false;
dtl.ItIsDelete = false;
dtl.Update();
attrs = new MapAttrs(dtl.No);
foreach (MapAttr attr in attrs)
{
if (attr.DefValReal.Contains("@"))
{
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.setDefValReal(""); //清空默认值.
attr.SetValByKey("ExtDefVal", ""); //设置默认值.
attr.Update();
}
if (attr.UIIsEnable == true)
{
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.Update();
continue;
}
}
}
//把附件设置为只读.
FrmAttachments aths = new FrmAttachments(fk_mapdata);
foreach (FrmAttachment item in aths)
{
item.ItIsUpload = false;
item.HisDeleteWay = AthDeleteWay.DelSelf;
//如果是从开始节点表单导入的,就默认为, 按照主键PK的方式显示.
if (fk_mapdata.IndexOf("ND") == 0)
{
item.DataRefNoOfObj = "AttachM1";
}
item.Update();
}
}
/// <summary>
/// 导入表单
/// </summary>
/// <param name="specFrmID">指定的表单ID</param>
/// <param name="ds">表单数据</param>
/// <param name="isSetReadonly">是否设置只读?</param>
/// <returns></returns>
public static MapData ImpMapData(string specFrmID, DataSet ds)
{
if (DataType.IsNullOrEmpty(specFrmID) == true)
ImpMapData(ds);
#region 检查导入的数据是否完整.
string errMsg = "";
//if (ds.Tables[0].TableName != "Sys_MapData")
// errMsg += "@非表单模板。";
if (ds.Tables.Contains("WF_Flow") == true)
errMsg += "@此模板文件为流程模板。";
if (ds.Tables.Contains("Sys_MapAttr") == false)
errMsg += "@缺少表:Sys_MapAttr";
if (ds.Tables.Contains("Sys_MapData") == false)
errMsg += "@缺少表:Sys_MapData";
DataTable dtCheck = ds.Tables["Sys_MapAttr"];
bool isHave = false;
foreach (DataRow dr in dtCheck.Rows)
{
if (dr["KeyOfEn"].ToString() == "OID")
{
isHave = true;
break;
}
}
if (isHave == false)
errMsg += "@表单模版缺少列:OID";
if (errMsg != "")
throw new Exception("@以下错误不可导入,可能的原因是非表单模板文件:" + errMsg);
#endregion
// 定义在最后执行的sql.
string endDoSQL = "";
MapData mdOld = new MapData();
mdOld.No = specFrmID;
int count = mdOld.RetrieveFromDBSources();
if (count == 1)
mdOld.Delete();
// 求出dataset的map.
string oldMapID = "";
DataTable dtMap = ds.Tables["Sys_MapData"];
if (dtMap.Rows.Count == 1)
{
oldMapID = dtMap.Rows[0]["No"].ToString();
}
else
{
// 求旧的表单ID.
foreach (DataRow dr in dtMap.Rows)
oldMapID = dr["No"].ToString();
if (DataType.IsNullOrEmpty(oldMapID) == true)
oldMapID = dtMap.Rows[0]["No"].ToString();
}
//现在表单的类型
FrmType frmType = mdOld.HisFrmType;
//业务类型
int entityType = mdOld.HisEntityType;
//mdOld.Delete();
string timeKey = DBAccess.GenerGUID();
#region 表单元素
foreach (DataTable dt in ds.Tables)
{
int idx = 0;
switch (dt.TableName)
{
case "Sys_MapDtl":
foreach (DataRow dr in dt.Rows)
{
MapDtl dtl = new MapDtl();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
//编号列.
string colName = dc.ColumnName.ToLower();
if (colName.Equals("no") || colName.Equals("name") || colName.Equals("fk_mapdata"))
dtl.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
else
dtl.SetValByKey(dc.ColumnName, val.ToString());
}
dtl.Insert();
}
break;
case "Sys_MapData":
foreach (DataRow dr in dt.Rows)
{
MapData md = new MapData();
string htmlCode = "";
foreach (DataColumn dc in dt.Columns)
{
if (dc.ColumnName.Equals("HtmlTemplateFile") == true)
{
htmlCode = dr[dc.ColumnName] as string;
continue;
}
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
string colName = dc.ColumnName.ToLower();
if (colName.Equals("no") == true || colName.Equals("name") == true)
md.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
else
md.SetValByKey(dc.ColumnName, val.ToString());
}
//表单类别编号不为空,则用原表单类别编号
md.FormTreeNo = mdOld.FormTreeNo;
if (DataType.IsNullOrEmpty(mdOld.PTable) == false)
md.PTable = mdOld.PTable;
//如果物理表为空,则使用编号为物理数据表
if (DataType.IsNullOrEmpty(md.PTable.Trim()) == true)
md.PTable = md.No;
if (DataType.IsNullOrEmpty(mdOld.Name) == false)
md.Name = mdOld.Name;
if (count == 1)
md.HisFrmType = mdOld.HisFrmType;
else
frmType = md.HisFrmType;
if (entityType != md.HisEntityType)
md.HisEntityType = entityType;
//表单应用类型保持不变
md.AppType = mdOld.AppType;
if (md.DirectUpdate() == 0)
md.DirectInsert();
Cache2019.UpdateRow(md.ToString(), md.No.ToString(), md.Row);
//如果是开发者表单赋值HtmlTemplateFile数据库的值并保存到DataUser下
if (frmType == FrmType.Develop)
{
// string htmlCode = DBAccess.GetBigTextFromDB("Sys_MapData", "No", oldMapID, "HtmlTemplateFile");
if (DataType.IsNullOrEmpty(htmlCode) == false)
{
htmlCode = htmlCode.Replace(oldMapID, specFrmID);
//保存到数据库存储html文件
//保存到DataUser/CCForm/HtmlTemplateFile/文件夹下
string filePath = BP.Difference.SystemConfig.PathOfDataUser + "CCForm/HtmlTemplateFile/";
if (Directory.Exists(filePath) == false)
Directory.CreateDirectory(filePath);
filePath = filePath + md.No + ".htm";
//写入到html 中
DataType.WriteFile(filePath, htmlCode);
// HtmlTemplateFile 保存到数据库中
DBAccess.SaveBigTextToDB(htmlCode, "Sys_MapData", "No", md.No, "HtmlTemplateFile");
}
else
{
//如果htmlCode是空的需要删除当前节点的html文件
string filePath = BP.Difference.SystemConfig.PathOfDataUser + "CCForm/HtmlTemplateFile/" + md.No + ".htm";
if (File.Exists(filePath) == true)
File.Delete(filePath);
DBAccess.SaveBigTextToDB("", "Sys_MapData", "No", md.No, "HtmlTemplateFile");
}
}
}
break;
case "Sys_FrmBtn":
foreach (DataRow dr in dt.Rows)
{
idx++;
FrmBtn en = new FrmBtn();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
//en.setMyPK("Btn_" + idx + "_" + fk_mapdata;
en.setMyPK(DBAccess.GenerGUID());
en.Insert();
}
break;
case "Sys_FrmImg":
foreach (DataRow dr in dt.Rows)
{
idx++;
FrmImg en = new FrmImg();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
if (DataType.IsNullOrEmpty(en.KeyOfEn) == true)
en.setMyPK(DBAccess.GenerGUID());
en.Insert();
}
break;
case "Sys_FrmImgAth":
foreach (DataRow dr in dt.Rows)
{
idx++;
FrmImgAth en = new FrmImgAth();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
if (DataType.IsNullOrEmpty(en.CtrlID))
en.CtrlID = "ath" + idx;
en.Insert();
}
break;
case "Sys_FrmRB":
foreach (DataRow dr in dt.Rows)
{
idx++;
FrmRB en = new FrmRB();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
try
{
en.Save();
}
catch
{
}
}
break;
case "Sys_FrmAttachment":
foreach (DataRow dr in dt.Rows)
{
idx++;
FrmAttachment en = new FrmAttachment();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
en.setMyPK(specFrmID + "_" + en.GetValByKey("NoOfObj"));
try
{
en.Insert();
}
catch
{
}
}
break;
case "Sys_MapFrame":
foreach (DataRow dr in dt.Rows)
{
idx++;
MapFrame en = new MapFrame();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
en.DirectInsert();
}
break;
case "Sys_MapExt":
foreach (DataRow dr in dt.Rows)
{
idx++;
MapExt en = new MapExt();
string text = "";
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
if (dc.ColumnName.Equals("HtmlText") == true)
{
text = dr[dc.ColumnName] as string;
continue;
}
if (DataType.IsNullOrEmpty(val.ToString()) == true)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
//执行保存并统一生成PK的规则.
en.InitPK();
en.DirectSave();
if (en.ExtType.Equals("HtmlText") == true && DataType.IsNullOrEmpty(text) == false)
en.SaveBigNoteHtmlText(text);
}
break;
case "Sys_MapAttr":
foreach (DataRow dr in dt.Rows)
{
MapAttr en = new MapAttr();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
en.setMyPK(en.FrmID + "_" + en.KeyOfEn);
//直接插入.
try
{
en.DirectInsert();
//判断该字段是否是大文本 例如注释、说明
if (en.UIContralType == UIContralType.BigText)
{
//判断原文件是否存在
string file = BP.Difference.SystemConfig.PathOfDataUser + "CCForm/BigNoteHtmlText/" + oldMapID + ".htm";
//若文件存在,则复制
if (System.IO.File.Exists(file) == true)
{
string newFile = BP.Difference.SystemConfig.PathOfDataUser + "CCForm/BigNoteHtmlText/" + specFrmID + ".htm";
if (System.IO.File.Exists(newFile) == true)
System.IO.File.Delete(newFile);
System.IO.File.Copy(file, newFile);
}
}
}
catch
{
}
}
break;
case "Sys_GroupField":
foreach (DataRow dr in dt.Rows)
{
idx++;
GroupField en = new GroupField();
foreach (DataColumn dc in dt.Columns)
{
object val = dr[dc.ColumnName] as object;
if (val == null)
continue;
try
{
en.SetValByKey(dc.ColumnName, val.ToString().Replace(oldMapID, specFrmID));
}
catch
{
throw new Exception("val:" + val.ToString() + "oldMapID:" + oldMapID + "fk_mapdata:" + specFrmID);
}
}
int beforeID = en.OID;
en.OID = 0;
en.DirectInsert();
endDoSQL += "@UPDATE Sys_MapAttr SET GroupID=" + en.OID + " WHERE FK_MapData='" + specFrmID + "' AND GroupID='" + beforeID + "'";
}
break;
case "Sys_Enum":
case "Sys_Enums":
foreach (DataRow dr in dt.Rows)
{
SysEnum se = new Sys.SysEnum();
foreach (DataColumn dc in dt.Columns)
{
string val = dr[dc.ColumnName].ToString();// as string;
se.SetValByKey(dc.ColumnName, val);
}
if (BP.Difference.SystemConfig.CCBPMRunModel == CCBPMRunModel.SAAS)
{
se.OrgNo = BP.Web.WebUser.OrgNo;
// se.RefPK = se.OrgNo + "_" + se.EnumKey;
se.setMyPK(se.EnumKey + "_" + se.Lang + "_" + se.IntKey + "_" + se.OrgNo);
if (se.IsExits)
continue;
}
else
{
se.setMyPK(se.EnumKey + "_" + se.Lang + "_" + se.IntKey);
if (se.IsExits)
continue;
}
se.Insert();
}
break;
case "Sys_EnumMain":
foreach (DataRow dr in dt.Rows)
{
SysEnumMain sem = new Sys.SysEnumMain();
foreach (DataColumn dc in dt.Columns)
{
string val = dr[dc.ColumnName].ToString();// as string;
if (val == null)
continue;
sem.SetValByKey(dc.ColumnName, val);
}
if (BP.Difference.SystemConfig.CCBPMRunModel == CCBPMRunModel.SAAS)
{
sem.OrgNo = BP.Web.WebUser.OrgNo;
sem.No = sem.OrgNo + "_" + sem.EnumKey;
if (sem.IsExits)
continue;
}
else
{
if (sem.IsExits)
continue;
}
sem.Insert();
}
break;
case "WF_Node":
if (dt.Rows.Count > 0)
{
endDoSQL += "@UPDATE WF_Node SET FWCSta=2"
+ ",FWC_X=" + dt.Rows[0]["FWC_X"]
+ ",FWC_Y=" + dt.Rows[0]["FWC_Y"]
+ ",FWC_H=" + dt.Rows[0]["FWC_H"]
+ ",FWC_W=" + dt.Rows[0]["FWC_W"]
+ ",FWCType=" + dt.Rows[0]["FWCType"]
+ " WHERE NodeID=" + specFrmID.Replace("ND", "");
}
break;
default:
break;
}
}
#endregion
//执行最后结束的sql.
DBAccess.RunSQLs(endDoSQL);
MapData mdNew = new MapData(specFrmID);
mdNew.RepairMap();
if (mdNew.No.IndexOf("ND") == 0)
{
mdNew.FormTreeNo = "";
}
mdNew.Update();
return mdNew;
}
/// <summary>
/// 修复map.
/// </summary>
public void RepairMap()
{
GroupFields gfs = new GroupFields(this.No);
if (gfs.Count == 0)
{
GroupField gf = new GroupField();
gf.FrmID = this.No;
gf.Lab = this.Name;
gf.Insert();
string sqls = "";
sqls += "@UPDATE Sys_MapDtl SET GroupID=" + gf.OID + " WHERE FK_MapData='" + this.No + "'";
sqls += "@UPDATE Sys_MapAttr SET GroupID=" + gf.OID + " WHERE FK_MapData='" + this.No + "'";
//sqls += "@UPDATE Sys_MapFrame SET GroupID=" + gf.OID + " WHERE FK_MapData='" + this.No + "'";
sqls += "@UPDATE Sys_FrmAttachment SET GroupID=" + gf.OID + " WHERE FK_MapData='" + this.No + "'";
DBAccess.RunSQLs(sqls);
}
else
{
if (BP.Difference.SystemConfig.AppCenterDBType != DBType.Oracle)
{
GroupField gfFirst = gfs[0] as GroupField;
string sqls = "";
// sqls += "@UPDATE Sys_MapAttr SET GroupID=" + gfFirst.OID + " WHERE MyPK IN (SELECT X.MyPK FROM (SELECT MyPK FROM Sys_MapAttr WHERE GroupID NOT IN (SELECT OID FROM Sys_GroupField WHERE FrmID='" + this.No + "') or GroupID is null) AS X) AND FK_MapData='" + this.No + "' ";
sqls += "@UPDATE Sys_FrmAttachment SET GroupID=" + gfFirst.OID + " WHERE MyPK IN (SELECT X.MyPK FROM (SELECT MyPK FROM Sys_FrmAttachment WHERE GroupID NOT IN (SELECT OID FROM Sys_GroupField WHERE FrmID='" + this.No + "')) AS X) AND FK_MapData='" + this.No + "' ";
#warning 这些sql 对于Oracle 有问题,但是不影响使用.
try
{
DBAccess.RunSQLs(sqls);
}
catch
{
}
}
}
BP.Sys.MapAttr attr = new BP.Sys.MapAttr();
if (this.EnPK == "OID")
{
if (attr.IsExit(MapAttrAttr.KeyOfEn, "OID", MapAttrAttr.FK_MapData, this.No) == false)
{
attr.FrmID =this.No;
attr.setKeyOfEn("OID");
attr.setName("OID");
attr.setMyDataType(DataType.AppInt);
attr.setUIContralType(UIContralType.TB);
attr.setLGType(FieldTypeS.Normal);
attr.SetValByKey(MapAttrAttr.UIVisible, false);
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.DefVal = "0";
attr.HisEditType = BP.En.EditType.Readonly;
attr.Insert();
}
}
if (this.EnPK == "No" || this.EnPK == "MyPK")
{
if (attr.IsExit(MapAttrAttr.KeyOfEn, this.EnPK, MapAttrAttr.FK_MapData, this.No) == false)
{
attr.FrmID =this.No;
attr.setKeyOfEn(this.EnPK);
attr.Name = this.EnPK;
attr.setMyDataType(DataType.AppInt);
attr.setUIContralType(UIContralType.TB);
attr.setLGType(FieldTypeS.Normal);
attr.SetValByKey(MapAttrAttr.UIVisible, false);
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.DefVal = "0";
attr.HisEditType = BP.En.EditType.Readonly;
attr.Insert();
}
}
if (attr.IsExit(MapAttrAttr.KeyOfEn, "RDT", MapAttrAttr.FK_MapData, this.No) == false)
{
attr = new BP.Sys.MapAttr();
attr.FrmID =this.No;
attr.setEditType(EditType.UnDel);
attr.setKeyOfEn("RDT");
attr.setName("更新时间");
attr.setGroupID(0);
attr.setMyDataType(DataType.AppDateTime);
attr.setUIContralType(UIContralType.TB);
attr.setLGType(FieldTypeS.Normal);
attr.SetValByKey(MapAttrAttr.UIVisible, false);
attr.SetValByKey(MapAttrAttr.UIIsEnable, false);
attr.DefVal = "@RDT";
attr.Tag = "1";
attr.Insert();
}
//检查特殊UIBindkey丢失的问题.
MapAttrs attrs = new MapAttrs();
attrs.Retrieve(MapAttrAttr.FK_MapData, this.No);
foreach (MapAttr item in attrs)
{
if (item.LGType == FieldTypeS.Enum || item.LGType == FieldTypeS.FK)
{
if (DataType.IsNullOrEmpty(item.UIBindKey) == true)
{
item.setLGType(FieldTypeS.Normal);
item.setUIContralType(UIContralType.TB);
item.Update();
}
}
}
}
protected override bool beforeInsert()
{
if (this.HisFrmType == FrmType.Url || this.HisFrmType == FrmType.Entity)
{
}
else
{
this.PTable = BP.Pub.PubClass.DealToFieldOrTableNames(this.PTable);
}
//写入日志.
if (this.No.StartsWith("ND") == false)
BP.Sys.Base.Glo.WriteUserLog("新建表单:" + this.No + " - " + this.Name);
this.Ver2022 = 1;
return base.beforeInsert();
}
/// <summary>
/// 创建MapData后插入一条版本数据
/// </summary>
protected override void afterInsert()
{
if (DataType.IsNullOrEmpty(this.FormTreeNo) == true)
{
base.afterInsert();
return;
}
MapDataVer ver = new MapDataVer();
ver.MyPK = this.No + ".1";
ver.Ver = 1; //设置当前为主版本.
ver.FrmID = this.No; //设置表单ID.
ver.ItIsRel = 1; //设置为主版本.
ver.Rec = WebUser.No;
ver.RecName = WebUser.Name;
ver.RDT = DataType.CurrentDateTime;
//设置数量.
ver.AttrsNum = 0;
ver.AthsNum = 0;
ver.DtlsNum = 0;
ver.ExtsNum = 0;
ver.Insert();
base.afterInsert();
}
protected override bool beforeUpdateInsertAction()
{
if (this.HisFrmType == FrmType.Url || this.HisFrmType == FrmType.Entity)
return base.beforeUpdateInsertAction();
//clear外键实体数量的缓存.
this.ClearAutoNumCache(false);
this.PTable = PubClass.DealToFieldOrTableNames(this.PTable);
//修改2021-09-04 注释,不知道这个代码的作用
//MapAttrs.Retrieve(MapAttrAttr.FK_MapData, PTable);
//设置OrgNo. 如果是管理员,就设置他所在的部门编号。
if (BP.Difference.SystemConfig.CCBPMRunModel != CCBPMRunModel.Single)
this.OrgNo = BP.Web.WebUser.OrgNo;
//判断是否有多个主键字段?
// string sql = "SELECT ";
//检查主键.
CheckPKFields(this.No, this.Name);
//清除缓存.
this.ClearCache();
return base.beforeUpdateInsertAction();
}
public static string CheckPKFields(string frmID, string name)
{
string sql = "SELECT KeyOfEn, Name FROM Sys_MapAttr WHERE FK_MapData='" + frmID + "' ";
sql += " AND ( ";
sql += " KeyOfEn='OID' ";
sql += " OR KeyOfEn='No' ";
sql += " OR KeyOfEn='MyPK' ";
sql += " OR KeyOfEn='NodeID' ";
sql += " OR KeyOfEn='WorkID' ";
sql += " ) ";
DataTable dt = DBAccess.RunSQLReturnTable(sql);
if (dt.Rows.Count == 1)
return "数据正确.";
if (dt.Rows.Count == 0)
return "err@表单缺少主键." + frmID + "," + name;
string msg = "err@FrmID=" + frmID + name + "主键不明确.";
foreach (DataRow dr in dt.Rows)
{
msg += "@" + dr[0] + "," + dr[1].ToString();
}
return msg;
}
/// <summary>
/// 更新版本
/// </summary>
public void UpdateVer()
{
string sql = "UPDATE Sys_MapData SET VER='" + DataType.CurrentDateTimess + "' WHERE No='" + this.No + "'";
DBAccess.RunSQL(sql);
}
protected override bool beforeDelete()
{
#region 判断是否是节点表单?如果是,判断节点是否被删除了.
//if (this.No.StartsWith("ND") == true)
//{
// string frmID = this.No.Replace("ND", "");
// if (BP.DA.DataType.IsNumStr(frmID) == true)
// {
// int nodeID = int.Parse(frmID);
// int count = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) as NUM FROM WF_Node WHERE NodeID=" + nodeID);
// if (count == 1)
// throw new Exception("err@删除节点表单前,需要删除节点数据."+this.No+" - " +this.Name);
// }
//}
#endregion 判断是否是节点表单?如果是,判断节点是否被删除了.
#region 检查完整性.
string sql = "";
//如果存在版本就不能删除
sql = "SELECT count(*) From Sys_MapDataVer Where FrmID='" + this.No + "' AND Ver!=" + this.Ver2022;
try
{
if (DBAccess.RunSQLReturnValInt(sql) > 0)
{
throw new Exception("表单存在其他的版本,请删除其他版本后再删除表单");
//return false;
}
}
catch (Exception ex)
{
MapDataVer mv = new MapDataVer();
mv.CheckPhysicsTable();
if (DBAccess.RunSQLReturnValInt(sql) > 0)
{
throw new Exception("表单存在其他的版本,请删除其他版本后再删除表单");
//return false;
}
}
//如果当前版本是主版本,需要删除主版本的信息
sql = "SELECT Ver From Sys_MapDataVer WHERE FrmID='" + this.No + "' AND IsRel=1";
int ver = DBAccess.RunSQLReturnValInt(sql, 0);
if (ver == this.Ver2022)
{
//删除主版本的信息
MapData md = new MapData();
md.No = this.No + "." + ver;
if (md.RetrieveFromDBSources() == 1)
md.Delete();
DBAccess.RunSQL("DELETE FROM Sys_MapDataVer WHERE MyPK='" + md.No + "'");
}
sql = "";
sql = "SELECT * FROM Sys_MapDtl WHERE FK_MapData ='" + this.No + "'";
DataTable Sys_MapDtl = DBAccess.RunSQLReturnTable(sql);
string whereFK_MapData = "FK_MapData= '" + this.No + "' ";
string whereEnsName = "FrmID= '" + this.No + "' ";
string whereNo = "No='" + this.No + "' ";
foreach (DataRow dr in Sys_MapDtl.Rows)
{
// ids += ",'" + dr["No"] + "'";
whereFK_MapData += " OR FK_MapData='" + dr["No"] + "' ";
whereEnsName += " OR FrmID='" + dr["No"] + "' ";
whereNo += " OR No='" + dr["No"] + "' ";
}
#endregion 检查完整性.
#region 删除相关的数据。
sql = "DELETE FROM Sys_MapDtl WHERE FK_MapData='" + this.No + "'";
// sql += "@DELETE FROM Sys_FrmLine WHERE " + whereFK_MapData;
//@hongyan.
if (DBAccess.IsExitsTableCol("Sys_FrmEvent", "FrmID"))
DBAccess.RunSQL("DELETE FROM Sys_FrmEvent WHERE " + whereEnsName);
if (DBAccess.IsExitsTableCol("Sys_FrmEvent", "FK_MapData"))
DBAccess.RunSQL("DELETE FROM Sys_FrmEvent WHERE " + whereFK_MapData);
sql += "@DELETE FROM Sys_FrmBtn WHERE " + whereFK_MapData;
// sql += "@DELETE FROM Sys_FrmLab WHERE " + whereFK_MapData;
//sql += "@DELETE FROM Sys_FrmLink WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_FrmImg WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_FrmImgAth WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_FrmRB WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_FrmAttachment WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_MapFrame WHERE " + whereFK_MapData;
if (this.No.Contains("BP.") == false)
sql += "@DELETE FROM Sys_MapExt WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_MapAttr WHERE " + whereFK_MapData;
sql += "@DELETE FROM Sys_GroupField WHERE " + whereEnsName;
sql += "@DELETE FROM Sys_MapData WHERE " + whereNo;
// sql += "@DELETE FROM Sys_M2M WHERE " + whereFK_MapData;
sql += "@DELETE FROM WF_FrmNode WHERE FK_Frm='" + this.No + "'";
sql += "@DELETE FROM Sys_FrmSln WHERE " + whereFK_MapData;
//sql += "@DELETE FROM Sys_MapDataVer WHERE " + whereFK_MapData;
DBAccess.RunSQLs(sql);
#endregion 删除相关的数据。
#region 删除物理表。
//如果存在物理表.
if (DBAccess.IsExitsObject(this.PTable) && this.PTable.IndexOf("ND") == 0)
{
//如果其他表单引用了该表,就不能删除它.
sql = "SELECT COUNT(No) AS NUM FROM Sys_MapData WHERE PTable='" + this.PTable + "' OR ( PTable='' AND No='" + this.PTable + "')";
if (DBAccess.RunSQLReturnValInt(sql, 0) > 1)
{
/*说明有多个表单在引用.*/
}
else
{
// edit by zhoupeng 误删已经有数据的表.
if (DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM " + this.PTable + " WHERE 1=1 ") == 0)
DBAccess.RunSQL("DROP TABLE " + this.PTable);
}
}
MapDtls dtls = new MapDtls(this.No);
foreach (MapDtl dtl in dtls)
dtl.Delete();
#endregion
#region 删除注册到的外检表.
SFTables sfs = new SFTables();
sfs.Retrieve(SFTableAttr.SrcTable, this.PTable);
foreach (SFTable item in sfs)
{
if (item.IsCanDelete() == null)
item.Delete();
}
#endregion 删除注册到的外检表.
#region 属性.
#endregion 属性.
//写入日志.
if (this.No.StartsWith("ND") == false)
BP.Sys.Base.Glo.WriteUserLog("删除表单:" + this.No + " - " + this.Name);
return base.beforeDelete();
}
#endregion 常用方法.
#region 与Excel相关的操作 .
/// <summary>
/// 获得Excel文件流
/// </summary>
/// <param name="oid"></param>
/// <returns></returns>
public bool ExcelGenerFile(string pkValue, ref byte[] bytes, string saveTo)
{
try
{
byte[] by = DBAccess.GetByteFromDB(this.PTable, this.EnPK, pkValue, saveTo);
if (by != null)
{
bytes = by;
return true;
}
else //说明当前excel文件没有生成.
{
string tempExcel = BP.Difference.SystemConfig.PathOfDataUser + "FrmVSTOTemplate/" + this.No + ".xlsx";
if (System.IO.File.Exists(tempExcel) == true)
{
bytes = DataType.ConvertFileToByte(tempExcel);
return false;
}
else //模板文件也不存在时
{
throw new Exception("@没有找到模版文件." + tempExcel + " 请确认表单配置.");
}
}
}
catch (Exception ex)
{
BP.DA.Log.DebugWriteError("读取excel失败" + ex.Message);
return false;
}
}
/// <summary>
/// 保存excel文件
/// </summary>
/// <param name="pkValue"></param>
/// <param name="bty"></param>
/// <param name="saveTo"></param>
public void ExcelSaveFile(string pkValue, byte[] bty, string saveTo)
{
DBAccess.SaveBytesToDB(bty, this.PTable, this.EnPK, pkValue, saveTo);
}
#endregion 与Excel相关的操作 .
#region 与Word相关的操作 .
/// <summary>
/// 获得Excel文件流
/// </summary>
/// <param name="pkValue"></param>
/// <returns></returns>
public void WordGenerFile(string pkValue, ref byte[] bytes, string saveTo)
{
byte[] by = DBAccess.GetByteFromDB(this.PTable, this.EnPK, pkValue, saveTo);
if (by != null)
{
bytes = by;
return;
}
else //说明当前excel文件没有生成.
{
string tempExcel = BP.Difference.SystemConfig.PathOfDataUser + "FrmVSTOTemplate/" + this.No + ".docx";
if (System.IO.File.Exists(tempExcel) == false)
tempExcel = BP.Difference.SystemConfig.PathOfDataUser + "FrmVSTOTemplate/NDxxxRpt.docx";
bytes = DataType.ConvertFileToByte(tempExcel);
return;
}
}
/// <summary>
/// 保存excel文件
/// </summary>
/// <param name="pkValue"></param>
/// <param name="bty"></param>
public void WordSaveFile(string pkValue, byte[] bty, string saveTo)
{
DBAccess.SaveBytesToDB(bty, this.PTable, this.EnPK, pkValue, saveTo);
}
#endregion 与Excel相关的操作 .
/// <summary>
/// 创建版本
/// </summary>
public string CreateMapDataVer()
{
//创建版本之前先判断当前版本是不是有数据
if (BP.DA.DBAccess.IsExitsObject(this.PTable) == false)
{
//MapData md = new MapData(this.No);
GEEntity ge = new GEEntity(this.No);
ge.CheckPhysicsTable();
}
//获得最大的版本数.
int count = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) From " + this.PTable + " WHERE AtPara NOT LIKE '%@FrmVer=%'");
if (count == 0)
return "表单" + this.Name + "版本" + this.Ver2022 + "还没有使用,不用创建新的版本。";
MapDataVer ver = new MapDataVer();
MapDataVers vers = new MapDataVers();
vers.Retrieve("FrmID", this.No);
if (vers.Count == 0)
{
ver.MyPK = this.No + ".1";
ver.Ver = 1; //设置当前为主版本.
ver.FrmID = this.No; //设置表单ID.
ver.ItIsRel = 1; //设置为主版本.
ver.Rec = Web.WebUser.No;
ver.RecName = Web.WebUser.Name;
ver.RDT = DataType.CurrentDateTime;
//设置数量.
ver.AttrsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_MapAttr WHERE FK_MapData='" + this.No + "'");
ver.AthsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_Frmattachment WHERE FK_MapData='" + this.No + "'");
ver.DtlsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_MapDtl WHERE FK_MapData='" + this.No + "'");
ver.ExtsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_MapExt WHERE FK_MapData='" + this.No + "'");
ver.Insert();
this.Ver2022 = ver.Ver; //更新当前的版本.
this.Update();
//执行复制,表单.
BP.Sys.CCFormAPI.CopyFrm(this.No, this.No + "." + this.Ver2022, this.Name + "." + ver.Ver, this.FormTreeNo);
return "创建成功." + ver.GetValByKey(MapDataVerAttr.Ver);
}
//缺少AtPara字段
MapAttr mattr = new MapAttr();
mattr.setMyPK(this.No + "_AtPara");
if (mattr.RetrieveFromDBSources() == 0)
{
mattr.FrmID =this.No;
mattr.HisEditType = EditType.UnDel;
mattr.setKeyOfEn("AtPara");
mattr.setName("参数"); // 单据编号
mattr.setMyDataType(DataType.AppString);
mattr.setUIContralType(UIContralType.TB);
mattr.setLGType(FieldTypeS.Normal);
mattr.setUIVisible(false);
mattr.setUIIsEnable(false);
mattr.UIIsLine = false;
mattr.setMinLen(0);
mattr.setMaxLen(4000);
mattr.Idx = -100;
mattr.Insert();
GEEntity en = new GEEntity(this.No);
en.CheckPhysicsTable();
}
//设置所有的版本为 0 .
string sql = "UPDATE Sys_MapDataVer SET IsRel=0 WHERE FrmID='" + this.No + "'";
DBAccess.RunSQL(sql);
#region 1. 创建新版本 执行复制,表单.
int maxVer = DBAccess.RunSQLReturnValInt("SELECT MAX(ver) FROM Sys_MapDataVer WHERE FrmID='" + this.No + "'", 0);
//执行复制,表单,创建新版本.
ver.Ver = maxVer + 1;
ver.MyPK = this.No + "." + ver.Ver;
ver.FrmID = this.No; //设置表单ID.
ver.ItIsRel = 1; //设置为主版本.
ver.Rec = Web.WebUser.No;
ver.RecName = Web.WebUser.Name;
ver.RDT = DataType.CurrentDateTime;
//设置数量.
ver.AttrsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_MapAttr WHERE FK_MapData='" + this.No + "'");
ver.AthsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_Frmattachment WHERE FK_MapData='" + this.No + "'");
ver.DtlsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_MapDtl WHERE FK_MapData='" + this.No + "'");
ver.ExtsNum = DBAccess.RunSQLReturnValInt("SELECT COUNT(*) FROM Sys_MapExt WHERE FK_MapData='" + this.No + "'");
ver.Insert(); //创建新版本.
//生成新的表单.
BP.Sys.CCFormAPI.CopyFrm(this.No, this.No + "." + ver.Ver, this.Name + "(Ver" + ver.Ver + ".0)", this.FormTreeNo);
//把版本的FK_FormTree清空
MapData md = new MapData(this.No + "." + ver.Ver);
md.FormTreeNo = "";
md.Update();
#endregion 1. 创建新版本 执行复制,表单.
#region 2. 覆盖旧版本.
string currVer = this.No + "." + this.Ver2022.ToString(); // this.No + "." + vers.Count;
md = new MapData();
md.No = currVer;
if (md.RetrieveFromDBSources() == 1)
md.Delete();
//把表单属性的FK_FormTree清空
BP.Sys.CCFormAPI.CopyFrm(this.No, currVer, this.Name + "(Ver" + this.Ver2022.ToString() + ".0)", this.FormTreeNo);
md.Retrieve();
md.FormTreeNo = "";
md.PTable = this.PTable;
md.Update();
//修改从表的存储表
MapDtls dtls = md.MapDtls;
foreach (MapDtl dtl in dtls)
{
if (dtl.PTable.Equals(dtl.No) == true)
{
dtl.PTable = dtl.PTable.Replace(currVer, this.No);
dtl.Update();
continue;
}
}
//把当前表单对应数据改成当前的版本
DBAccess.RunSQL("UPDATE " + md.PTable + " SET AtPara=CONCAT(AtPara,'@FrmVer=" + this.Ver2022 + "') WHERE AtPara NOT LIKE '%@FrmVer=%'");
#endregion 2. 覆盖旧版本.
#region 3. 更新当前版本号.
this.Ver2022 = ver.Ver; //更新当前的版本.
this.Update();
#endregion 3. 更新当前版本号.
return "创建成功,版本号:" + ver.Ver;
}
}
/// <summary>
/// 映射基础s
/// </summary>
public class MapDatas : EntitiesNoName
{
#region 构造
/// <summary>
/// 映射基础s
/// </summary>
public MapDatas()
{
}
/// <summary>
/// 得到它的 Entity
/// </summary>
public override Entity GetNewEntity
{
get
{
return new MapData();
}
}
#endregion
#region 为了适应自动翻译成java的需要,把实体转换成List.
/// <summary>
/// 转化成 java list,C#不能调用.
/// </summary>
/// <returns>List</returns>
public System.Collections.Generic.IList<MapData> ToJavaList()
{
return (System.Collections.Generic.IList<MapData>)this;
}
/// <summary>
/// 转化成list
/// </summary>
/// <returns>List</returns>
public System.Collections.Generic.List<MapData> Tolist()
{
System.Collections.Generic.List<MapData> list = new System.Collections.Generic.List<MapData>();
for (int i = 0; i < this.Count; i++)
{
list.Add((MapData)this[i]);
}
return list;
}
#endregion 为了适应自动翻译成java的需要,把实体转换成List.
}
}