/// <summary> /// 删除 /// </summary> public override void EntityDelete() { DBFormRule rule = new DBFormRule(); DBForm entity = EntityGet(); rule.RDelete(entity); }
/// <summary> /// 获得实体 /// </summary> /// <returns></returns> private DBForm EntityGet() { DBForm entity = new DBForm(); entity.ID = HTDataID; return(entity); }
/// <summary> /// 删除 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int Delete(BaseEntity p_Entity) { try { DBForm MasterEntity = (DBForm)p_Entity; if (MasterEntity.ID == 0) { return(0); } //删除主表数据 string Sql = ""; Sql = "DELETE FROM WH_DBForm WHERE " + "ID=" + SysString.ToDBString(MasterEntity.ID); //执行 int AffectedRows = 0; if (!this.sqlTransFlag) { AffectedRows = this.ExecuteNonQuery(Sql); } else { AffectedRows = sqlTrans.ExecuteNonQuery(Sql); } return(AffectedRows); } catch (BaseException E) { throw new BaseException(E.Message, E); } catch (Exception E) { throw new BaseException(FrameWorkMessage.GetAlertMessage((int)Message.CommonDBDelete), E); } }
/// <summary> /// 设置 /// </summary> public override void EntitySet() { DBForm entity = new DBForm(); entity.ID = HTDataID; bool findFlag = entity.SelectByID(); HTDataFormNo = entity.FormNo; txtFormNo.Text = entity.FormNo.ToString(); txtFormDate.DateTime = entity.FormDate; drpVendorID.EditValue = entity.VendorID; drpWHID.EditValue = entity.WHID; drpTargetWHID.EditValue = entity.TargetWHID; //drpFormListDBID.EditValue = entity.FormListDBID; txtTotalQty.Text = entity.TotalQty.ToString(); txtRemark.Text = entity.Remark; txtOutWHFormNo.Text = entity.OutWHFormNo; txtInWHFormNo.Text = entity.InWHFormNo; HTDataSubmitFlag = entity.SubmitFlag; HTDataDelFlag = entity.DelFlag; if (!findFlag) { } BindGridDts(); //SetIOFormDetail(); //BindPack(); }
/// <summary> /// Get all defined forms that have submitted form data /// </summary> /// <returns></returns> public IList <DBForm> GetAllForms() { using (SqlConnection sqlConnection = new SqlConnection(connectionString)) { try { sqlConnection.Open(); var getAllFormsSQL = new SqlCommand(SELECT_ALL_FORMS, sqlConnection); SqlDataReader reader = getAllFormsSQL.ExecuteReader(); IList <DBForm> allForms = new List <DBForm>(); while (reader.Read()) { string formId = reader.GetString(0); int count = reader.GetInt32(1); Form form = FormRepository.GetForm(formId); if (form != null) { DBForm dbForm = new DBForm(form); dbForm.Count = count; allForms.Add(dbForm); } } return(allForms); } catch (Exception e) { throw new DxaException("Could not get all forms.", e); } } }
/// <summary> /// 获得实体 /// </summary> /// <returns></returns> private DBForm EntityGet() { DBForm entity = new DBForm(); entity.ID = HTDataID; entity.SelectByID(); entity.FormNo = txtFormNo.Text.Trim(); entity.FormDate = txtFormDate.DateTime.Date; entity.VendorID = SysConvert.ToString(drpVendorID.EditValue); entity.WHID = SysConvert.ToString(drpWHID.EditValue); entity.TargetWHID = SysConvert.ToString(drpTargetWHID.EditValue); entity.FormListDBID = SysConvert.ToInt32(drpFormListDBID.EditValue); entity.Remark = txtRemark.Text.Trim(); return(entity); }
/// <summary> /// 删除 /// </summary> /// <param name="p_BE">要删除的实体</param> /// <param name="sqlTrans">事务类</param> public void RDelete(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); DBForm entity = (DBForm)p_BE; DBFormCtl control = new DBFormCtl(sqlTrans); control.Delete(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 修改 /// </summary> public override void EntityUpdate() { DBFormRule rule = new DBFormRule(); DBForm entity = EntityGet(); DBFormDts[] entitydts = EntityDtsGet(); decimal TotalQty = 0; decimal TotalAmount = 0; for (int i = 0; i < entitydts.Length; i++) { TotalQty += SysConvert.ToDecimal(entitydts[i].Qty); TotalAmount += SysConvert.ToDecimal(entitydts[i].Amount); } entity.TotalQty = TotalQty; entity.SubmitFlag = this.HTSubmitFlagUpdateGet(); rule.RUpdate(entity, entitydts); }
/// <summary> /// 新增(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RAdd(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); DBForm entity = (DBForm)p_BE; DBFormCtl control = new DBFormCtl(sqlTrans); entity.ID = (int)EntityIDTable.GetID((long)SysEntity.WH_DBForm, sqlTrans); control.AddNew(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 新增 /// </summary> public override int EntityAdd() { DBFormRule rule = new DBFormRule(); DBForm entity = EntityGet(); DBFormDts[] entitydts = EntityDtsGet(); decimal TotalQty = 0; decimal TotalAmount = 0; for (int i = 0; i < entitydts.Length; i++) { TotalQty += SysConvert.ToDecimal(entitydts[i].Qty); TotalAmount += SysConvert.ToDecimal(entitydts[i].Amount); } entity.TotalQty = TotalQty; entity.SubmitFlag = this.HTSubmitFlagInsertGet(); rule.RAdd(entity, entitydts); return(entity.ID); }
/// <summary> /// Get a specific form and its submitted data /// </summary> /// <param name="formId"></param> /// <returns></returns> public DBForm GetForm(string formId) { Form form = FormRepository.GetForm(formId); if (form == null) { Log.Warn("No form found in the Broker DB with ID: " + formId); return(null); } DBForm dbForm = new DBForm(form); using (SqlConnection sqlConnection = new SqlConnection(connectionString)) { try { sqlConnection.Open(); var getSubmittedFormsSQL = new SqlCommand(SELECT_SUBMITTED_FORMS, sqlConnection); getSubmittedFormsSQL.Parameters.Add("@FormId", SqlDbType.NVarChar).Value = form.FormId; SqlDataReader reader = getSubmittedFormsSQL.ExecuteReader(); IList <SubmittedForm> submittedForms = new List <SubmittedForm>(); dbForm.SubmittedForms = submittedForms; while (reader.Read()) { int id = reader.GetInt32(0); DateTime date = reader.GetDateTime(1); SubmittedForm submittedForm = new SubmittedForm { SequenceId = id, SubmitDate = date }; submittedForms.Add(submittedForm); } dbForm.Count = submittedForms.Count; return(dbForm); } catch (Exception e) { throw new DxaException("Could not get all forms.", e); } } }
/// <summary> /// 新增(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RAdd(BaseEntity p_BE, BaseEntity[] p_BE2, IDBTransAccess sqlTrans) { try { this.RAdd(p_BE, sqlTrans); DBForm entity = (DBForm)p_BE; DBFormDtsRule ruledts = new DBFormDtsRule(); for (int i = 0; i < p_BE2.Length; i++) { DBFormDts entityDts = (DBFormDts)p_BE2[i]; entityDts.MainID = entity.ID; entityDts.Seq = i + 1; ruledts.RAdd(entityDts, sqlTrans); } //ruledts.RSave((IOForm)p_BE, p_BE2, sqlTrans);//保存从表 //FormNoControlRule rulest = new FormNoControlRule(); //rulest.RAddSort((int)FormNoControlEnum.入库单号,sqlTrans); FormNoControlRule rulefn = new FormNoControlRule();//更新单号 int tempFormNoControlID = 0; string sql = "SELECT FormNoControlID FROM Enum_FormListDB WHERE ID=" + SysString.ToDBString(entity.FormListDBID); DataTable dt = sqlTrans.Fill(sql); if (dt.Rows.Count != 0) { tempFormNoControlID = SysConvert.ToInt32(dt.Rows[0]["FormNoControlID"].ToString()); } rulefn.RAddSort(tempFormNoControlID, sqlTrans); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
private void frmOutWHEdit_FormClosing(object sender, FormClosingEventArgs e) { try { if (HTDataID > 0) { DBForm entity = new DBForm(); entity.ID = HTDataID; entity.SelectByID(); if (entity.SubmitFlag == 0) { if (DialogResult.Yes != ShowConfirmMessage(this.Text + Environment.NewLine + "没有提交单据,是否确认关闭窗体")) { e.Cancel = true; } } } } catch (Exception E) { this.ShowMessage(E.Message); } }
/// <summary> /// 保存(传入事务处理) /// </summary> /// <param name="p_Entity"></param> /// <param name="p_BE"></param> /// <param name="sqlTrans"></param> public void RSave(DBForm p_Entity, BaseEntity[] p_BE, IDBTransAccess sqlTrans) { try { string sql = string.Empty; sql = "";//删除码单明细表,代码待补充;如果是入库要删除原始码单表,需要仔细研究,因为某些情况下(先验布)原始码单还是需要保存的 sql = "DELETE FROM WH_DBFormDts WHERE MainID=" + p_Entity.ID.ToString(); sql += " AND ID NOT IN" + string.Format("({0})", GetIDExist(p_BE)); sqlTrans.ExecuteNonQuery(sql);//删除原单据里应该删除的明细数据,即数据库里有但是UI里已经删除的数据 for (int i = 0; i < p_BE.Length; i++) { DBFormDts entitydts = (DBFormDts)p_BE[i]; if (entitydts.ID != 0)//ID不为0说明数据库中已经存在 { this.RUpdate(entitydts, sqlTrans); } else { entitydts.MainID = p_Entity.ID; this.RAdd(entitydts, sqlTrans); } } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
public static string GenerateForms(string CRLNo, params CatalogBase[] CatalogList) { List <DatabaseReq> DBReq = new List <DatabaseReq>(); foreach (CatalogBase catalog in CatalogList) { string fileName = catalog.SerializeToFile(); DatabaseReq databaseRequest = new DatabaseReq(); databaseRequest.Server = DBServerMapping[catalog.WarehouseNumber]; databaseRequest.Database = "Dropship"; databaseRequest.ScriptFiles = new List <ScriptFile> { new ScriptFile { FileName = fileName, PType = ProcessType.DI, OType = ObjectType.U, OName = "dbo.DispatchSql" } }; DBReq.Add(databaseRequest); } DBForm form = new DBForm("DispatchSql", "Feedback"); form.MessageCallback = new Action <string>(msg => Console.WriteLine(msg)); return(form.GenerateForm(Formnumber++, CRLNo, DBReq)); }
/// <summary> /// 新增 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int AddNew(BaseEntity p_Entity) { try { DBForm MasterEntity = (DBForm)p_Entity; if (MasterEntity.ID == 0) { return(0); } //新增主表数据 StringBuilder MasterField = new StringBuilder(); StringBuilder MasterValue = new StringBuilder(); MasterField.Append("INSERT INTO WH_DBForm("); MasterValue.Append(" VALUES("); MasterField.Append("ID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.ID) + ","); MasterField.Append("FormListDBID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.FormListDBID) + ","); MasterField.Append("FormNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.FormNo) + ","); MasterField.Append("FormDate" + ","); if (MasterEntity.FormDate != SystemConfiguration.DateTimeDefaultValue) { MasterValue.Append(SysString.ToDBString(MasterEntity.FormDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("WHID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.WHID) + ","); MasterField.Append("TargetWHID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.TargetWHID) + ","); MasterField.Append("TargetDtsSO" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.TargetDtsSO) + ","); MasterField.Append("OutWHFormNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.OutWHFormNo) + ","); MasterField.Append("OutWHFormID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.OutWHFormID) + ","); MasterField.Append("InWHFormNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.InWHFormNo) + ","); MasterField.Append("InWHFormID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.InWHFormID) + ","); MasterField.Append("SubmitFlag" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.SubmitFlag) + ","); MasterField.Append("SubmitOPID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.SubmitOPID) + ","); MasterField.Append("DelFlag" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.DelFlag) + ","); MasterField.Append("MakeOPID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.MakeOPID) + ","); MasterField.Append("MakeDate" + ","); if (MasterEntity.MakeDate != SystemConfiguration.DateTimeDefaultValue) { MasterValue.Append(SysString.ToDBString(MasterEntity.MakeDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("Remark" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.Remark) + ","); MasterField.Append("CheckOPID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.CheckOPID) + ","); MasterField.Append("CheckDate" + ","); if (MasterEntity.CheckDate != SystemConfiguration.DateTimeDefaultValue) { MasterValue.Append(SysString.ToDBString(MasterEntity.CheckDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("TotalQty" + ","); if (MasterEntity.TotalQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.TotalQty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("TotalPieceQty" + ","); if (MasterEntity.TotalPieceQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.TotalPieceQty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("VendorID" + ")"); MasterValue.Append(SysString.ToDBString(MasterEntity.VendorID) + ")"); //执行 int AffectedRows = 0; if (!this.sqlTransFlag) { AffectedRows = this.ExecuteNonQuery(MasterField.Append(MasterValue.ToString()).ToString()); } else { AffectedRows = sqlTrans.ExecuteNonQuery(MasterField.Append(MasterValue.ToString()).ToString()); } return(AffectedRows); } catch (BaseException E) { throw new BaseException(E.Message, E); } catch (Exception E) { throw new BaseException(FrameWorkMessage.GetAlertMessage((int)Message.CommonDBInsert), E); } }
/// <summary> /// 修改 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int Update(BaseEntity p_Entity) { try { DBForm MasterEntity = (DBForm)p_Entity; if (MasterEntity.ID == 0) { return(0); } //更新主表数据 StringBuilder UpdateBuilder = new StringBuilder(); UpdateBuilder.Append("UPDATE WH_DBForm SET "); UpdateBuilder.Append(" ID=" + SysString.ToDBString(MasterEntity.ID) + ","); UpdateBuilder.Append(" FormListDBID=" + SysString.ToDBString(MasterEntity.FormListDBID) + ","); UpdateBuilder.Append(" FormNo=" + SysString.ToDBString(MasterEntity.FormNo) + ","); if (MasterEntity.FormDate != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" FormDate=" + SysString.ToDBString(MasterEntity.FormDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" FormDate=null,"); } UpdateBuilder.Append(" WHID=" + SysString.ToDBString(MasterEntity.WHID) + ","); UpdateBuilder.Append(" TargetWHID=" + SysString.ToDBString(MasterEntity.TargetWHID) + ","); UpdateBuilder.Append(" TargetDtsSO=" + SysString.ToDBString(MasterEntity.TargetDtsSO) + ","); UpdateBuilder.Append(" OutWHFormNo=" + SysString.ToDBString(MasterEntity.OutWHFormNo) + ","); UpdateBuilder.Append(" OutWHFormID=" + SysString.ToDBString(MasterEntity.OutWHFormID) + ","); UpdateBuilder.Append(" InWHFormNo=" + SysString.ToDBString(MasterEntity.InWHFormNo) + ","); UpdateBuilder.Append(" InWHFormID=" + SysString.ToDBString(MasterEntity.InWHFormID) + ","); UpdateBuilder.Append(" SubmitFlag=" + SysString.ToDBString(MasterEntity.SubmitFlag) + ","); UpdateBuilder.Append(" SubmitOPID=" + SysString.ToDBString(MasterEntity.SubmitOPID) + ","); UpdateBuilder.Append(" DelFlag=" + SysString.ToDBString(MasterEntity.DelFlag) + ","); UpdateBuilder.Append(" MakeOPID=" + SysString.ToDBString(MasterEntity.MakeOPID) + ","); if (MasterEntity.MakeDate != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" MakeDate=" + SysString.ToDBString(MasterEntity.MakeDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" MakeDate=null,"); } UpdateBuilder.Append(" Remark=" + SysString.ToDBString(MasterEntity.Remark) + ","); UpdateBuilder.Append(" CheckOPID=" + SysString.ToDBString(MasterEntity.CheckOPID) + ","); if (MasterEntity.CheckDate != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" CheckDate=" + SysString.ToDBString(MasterEntity.CheckDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" CheckDate=null,"); } if (MasterEntity.TotalQty != 0) { UpdateBuilder.Append(" TotalQty=" + SysString.ToDBString(MasterEntity.TotalQty) + ","); } else { UpdateBuilder.Append(" TotalQty=null,"); } if (MasterEntity.TotalPieceQty != 0) { UpdateBuilder.Append(" TotalPieceQty=" + SysString.ToDBString(MasterEntity.TotalPieceQty) + ","); } else { UpdateBuilder.Append(" TotalPieceQty=null,"); } UpdateBuilder.Append(" VendorID=" + SysString.ToDBString(MasterEntity.VendorID)); UpdateBuilder.Append(" WHERE " + "ID=" + SysString.ToDBString(MasterEntity.ID)); //执行 int AffectedRows = 0; if (!this.sqlTransFlag) { AffectedRows = this.ExecuteNonQuery(UpdateBuilder.ToString()); } else { AffectedRows = sqlTrans.ExecuteNonQuery(UpdateBuilder.ToString()); } return(AffectedRows); } catch (BaseException E) { throw new BaseException(E.Message, E); } catch (Exception E) { throw new BaseException(FrameWorkMessage.GetAlertMessage((int)Message.CommonDBUpdate), E); } }
/// <summary> /// 审核 /// </summary> /// <param name="p_FormID">单据ID</param> /// <param name="p_Type">0/1/2/3:弃审/审核</param> public void RSubmit(int p_FormID, int p_Type, IDBTransAccess sqlTrans) { try { int p_TempType = p_Type;//处理状态 string sql = string.Empty; DBForm entity = new DBForm(sqlTrans); entity.ID = p_FormID; entity.SelectByID(); if (!RSubmitCheckJS(entity.FormDate, sqlTrans)) { throw new Exception("不允许操作,此单据日期之后已经有结算数据"); } if (entity.SubmitFlag == p_Type)//如果相同异常 { throw new Exception("单据状态重复设置,请关闭程序重新打开操作"); } int p_AuditFlag = 0; //sql = "SELECT FillDataTypeID,AuditFlag,WHQtyPosID,CheckQtyPer1,CheckQtyFrom,CheckQtyPer2,DZFlag FROM Enum_FormList WHERE ID=" + SysString.ToDBString(entity.SubType); //DataTable dtFormList = sqlTrans.Fill(sql); //if (dtFormList.Rows.Count != 0) //{ //p_AuditFlag = SysConvert.ToInt32(dtFormList.Rows[0]["AuditFlag"]); if (p_AuditFlag == 0)//不需要审核 { switch (p_Type) { case (int)ConfirmFlag.未提交: //p_Type=(int)ConfirmFlag.未提交; break; case (int)ConfirmFlag.已提交: p_Type = (int)ConfirmFlag.审核通过; break; case (int)ConfirmFlag.审核通过: // p_Type=(int)ConfirmFlag.审核通过; break; case (int)ConfirmFlag.审核拒绝: p_Type = (int)ConfirmFlag.未提交; break; } } #region 提交 sql = "UPDATE WH_IOForm SET SubmitFlag=" + SysString.ToDBString(p_Type); if (p_Type == (int)ConfirmFlag.审核通过 || p_Type == (int)ConfirmFlag.审核拒绝) { sql += ",SubmitOPID=" + SysString.ToDBString(ParamConfig.LoginName) + ",SubmitTime=" + SysString.ToDBString(DateTime.Now); } sql += " WHERE ID=" + p_FormID.ToString();//更新单据主表审核状态 sqlTrans.ExecuteNonQuery(sql); //IOFormDtsRule ruledts = new IOFormDtsRule(); //ruledts.RSubmit(p_FormID, TempSubmitType, dtFormList.Rows[0], sqlTrans);//操作子表库存 #endregion if (entity.SubmitFlag == p_Type)//如果相同异常 { throw new Exception("单据状态重复设置,请关闭程序重新打开操作"); } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 检查将要操作的数据是否符合业务规则 /// </summary> /// <param name="p_BE"></param> private void CheckCorrect(BaseEntity p_BE) { DBForm entity = (DBForm)p_BE; }