/// <summary> /// 获得实体 /// </summary> /// <returns></returns> private SaleOrderInstruct EntityGet() { SaleOrderInstruct entity = new SaleOrderInstruct(); entity.ID = HTDataID; entity.SelectByID(); entity.FormNo = txtFormNo.Text.Trim(); entity.OrderFormNo = txtOrderFormNo.Text.Trim(); entity.FormDate = txtFormDate.DateTime.Date; entity.ReqDate = txtReqDate.DateTime.Date; entity.SaleOPID = drpSaleOPID.Text.Trim(); entity.PBItemCode = txtPBItemCode.Text.Trim(); entity.PBDensity = txtPBDensity.Text.Trim(); entity.PBMWidth = txtPBMWidth.Text.Trim(); entity.PBMWeight = txtPBMWeight.Text.Trim(); entity.FactoryID2 = drpFactoryID2.Text.Trim(); entity.CPItemCode = txtCPItemCode.Text.Trim(); entity.CPDensity = txtCPDensity.Text.Trim(); entity.CPMWidth = txtCPMWidth.Text.Trim(); entity.CPMWeight = txtCPMWeight.Text.Trim(); entity.FactoryID3 = drpFactoryID3.Text.Trim(); entity.TecReq = txtTecReq.Text.Trim(); entity.PBQty = SysConvert.ToDecimal(txtPBQty.Text.Trim()); entity.BCPSampleQty = SysConvert.ToDecimal(txtBCPSampleQty.Text.Trim()); entity.PBSampleQty = SysConvert.ToDecimal(txtPBSampleQty.Text.Trim()); entity.MakeOPID = txtMakeOPID.Text.Trim(); entity.MakeOPName = txtMakeOPName.Text.Trim(); entity.MakeDate = txtMakeDate.DateTime.Date; entity.Remark = txtRemark.Text.Trim(); return(entity); }
/// <summary> /// 保存(传入事务处理) /// </summary> /// <param name="p_Entity"></param> /// <param name="p_BE"></param> /// <param name="sqlTrans"></param> public void RSave(SaleOrderInstruct p_Entity, BaseEntity[] p_BE, IDBTransAccess sqlTrans) { try { string sql = "DELETE FROM Sale_SaleOrderInstructDts WHERE MainID=" + p_Entity.ID.ToString(); sql += " AND ID NOT IN" + string.Format("({0})", GetIDExist(p_BE)); sqlTrans.ExecuteNonQuery(sql); //删除原单据里应该删除的明细数据,即数据库里有但是UI里已经删除的数据 sql = "SELECT ISNULL(MAX(Seq),0)+1 As MSEQ FROM Sale_SaleOrderInstructDts WHERE MainID=" + p_Entity.ID.ToString(); ////找到最大的Seq 将获得最大Seq的语句放到循环外更高效(多人操作时会有问题吗?) int MSEQ = SysConvert.ToInt32(sqlTrans.Fill(sql).Rows[0][0].ToString()); for (int i = 0; i < p_BE.Length; i++) { SaleOrderInstructDts entitydts = (SaleOrderInstructDts)p_BE[i]; if (entitydts.ID != 0)//ID不为0说明数据库中已经存在 { this.RUpdate(entitydts, sqlTrans); } else { entitydts.Seq = MSEQ; entitydts.MainID = p_Entity.ID; this.RAdd(entitydts, sqlTrans); MSEQ++;//最大值加1 } } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 删除 /// </summary> public override void EntityDelete() { SaleOrderInstructRule rule = new SaleOrderInstructRule(); SaleOrderInstruct entity = EntityGet(); rule.RDelete(entity); }
/// <summary> /// 删除 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int Delete(BaseEntity p_Entity) { try { SaleOrderInstruct MasterEntity = (SaleOrderInstruct)p_Entity; if (MasterEntity.ID == 0) { return(0); } //删除主表数据 string Sql = ""; Sql = "DELETE FROM Sale_SaleOrderInstruct 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> /// <returns></returns> private SaleOrderInstruct EntityGet() { SaleOrderInstruct entity = new SaleOrderInstruct(); entity.ID = HTDataID; return(entity); }
/// <summary> /// 新增(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RAdd(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); SaleOrderInstruct entity = (SaleOrderInstruct)p_BE; string sql = "SELECT FormNo FROM Sale_SaleOrderInstruct WHERE FormNo=" + SysString.ToDBString(entity.FormNo); DataTable dt = sqlTrans.Fill(sql); if (dt.Rows.Count > 0) { throw new BaseException("单号已存在,请双击重新生成单号"); } SaleOrderInstructCtl control = new SaleOrderInstructCtl(sqlTrans); entity.ID = (int)EntityIDTable.GetID((long)SysEntity.Sale_HandleEvent, sqlTrans); control.AddNew(entity); FormNoControlRule rulest = new FormNoControlRule(); rulest.RAddSort("Sale_SaleOrderInstruct", "FormNo", 0, sqlTrans); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 修改 /// </summary> public override void EntityUpdate() { SaleOrderInstructRule rule = new SaleOrderInstructRule(); SaleOrderInstruct entity = EntityGet(); SaleOrderInstructDts[] entitydts = EntityDtsGet(); entity.SubmitFlag = this.HTSubmitFlagUpdateGet(); rule.RUpdate(entity, entitydts); }
/// <summary> /// 新增 /// </summary> public override int EntityAdd() { SaleOrderInstructRule rule = new SaleOrderInstructRule(); SaleOrderInstruct entity = EntityGet(); SaleOrderInstructDts[] entitydts = EntityDtsGet(); entity.SubmitFlag = this.HTSubmitFlagInsertGet(); rule.RAdd(entity, entitydts); return(entity.ID); }
/// <summary> /// 检验字段值是否已存在 /// </summary> /// <param name="p_TableName">表名</param> /// <param name="p_FieldName">字段名</param> /// <param name="p_FieldValue">字段值</param> /// <param name="p_KeyField">主键(只考虑主键为ID的情况)</param> /// <param name="p_KeyValue">主键值</param> /// <param name="p_sqlTrans"></param> /// <returns></returns> private bool CheckFieldValueIsExist(BaseEntity p_BE, string p_FieldName, string p_FieldValue, IDBTransAccess p_sqlTrans) { SaleOrderInstruct entity = (SaleOrderInstruct)p_BE; bool ret = false; string sql = string.Format(" SELECT {0} FROM {1} WHERE 1=1 AND {0}={2} AND {3}<>{4}", p_FieldName, SaleOrderInstruct.TableName, SysString.ToDBString(p_FieldValue), "ID", entity.ID); DataTable dt = p_sqlTrans.Fill(sql); if (dt.Rows.Count != 0) { ret = true; } return(ret); }
/// <summary> /// 修改 /// </summary> /// <param name="p_BE">要修改的实体</param> /// <param name="sqlTrans">事务类</param> public void RUpdate(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); SaleOrderInstruct entity = (SaleOrderInstruct)p_BE; SaleOrderInstructCtl control = new SaleOrderInstructCtl(sqlTrans); control.Update(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 设置 /// </summary> public override void EntitySet() { SaleOrderInstruct entity = new SaleOrderInstruct(); entity.ID = HTDataID; bool findFlag = entity.SelectByID(); txtFormNo.Text = entity.FormNo.ToString(); txtOrderFormNo.Text = entity.OrderFormNo.ToString(); txtFormDate.DateTime = entity.FormDate; txtReqDate.DateTime = entity.ReqDate; drpSaleOPID.Text = entity.SaleOPID.ToString(); txtPBItemCode.Text = entity.PBItemCode.ToString(); txtPBDensity.Text = entity.PBDensity.ToString(); txtPBMWidth.Text = entity.PBMWidth.ToString(); txtPBMWeight.Text = entity.PBMWeight.ToString(); drpFactoryID2.Text = entity.FactoryID2.ToString(); txtCPItemCode.Text = entity.CPItemCode.ToString(); txtCPDensity.Text = entity.CPDensity.ToString(); txtCPMWidth.Text = entity.CPMWidth.ToString(); txtCPMWeight.Text = entity.CPMWeight.ToString(); drpFactoryID3.Text = entity.FactoryID3.ToString(); txtTecReq.Text = entity.TecReq.ToString(); txtPBQty.Text = entity.PBQty.ToString(); txtBCPSampleQty.Text = entity.BCPSampleQty.ToString(); txtPBSampleQty.Text = entity.PBSampleQty.ToString(); txtMakeOPID.Text = entity.MakeOPID.ToString(); txtMakeOPName.Text = entity.MakeOPName.ToString(); txtMakeDate.DateTime = entity.MakeDate; txtRemark.Text = entity.Remark.ToString(); HTDataSubmitFlag = entity.SubmitFlag; HTDataDelFlag = entity.DelFlag; if (!findFlag) { } BindGridDts(); }
/// <summary> /// 删除 /// </summary> /// <param name="p_BE">要删除的实体</param> /// <param name="sqlTrans">事务类</param> public void RDelete(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); SaleOrderInstruct entity = (SaleOrderInstruct)p_BE; SaleOrderInstructCtl control = new SaleOrderInstructCtl(sqlTrans); string sql = "DELETE FROM Sale_SaleOrderInstructDts WHERE MainID=" + entity.ID.ToString(); sqlTrans.ExecuteNonQuery(sql);//删除原单据明细数据 control.Delete(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 新增 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int AddNew(BaseEntity p_Entity) { try { SaleOrderInstruct MasterEntity = (SaleOrderInstruct)p_Entity; if (MasterEntity.ID == 0) { return(0); } //新增主表数据 StringBuilder MasterField = new StringBuilder(); StringBuilder MasterValue = new StringBuilder(); MasterField.Append("INSERT INTO Sale_SaleOrderInstruct("); MasterValue.Append(" VALUES("); MasterField.Append("ID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.ID) + ","); MasterField.Append("FormNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.FormNo) + ","); MasterField.Append("OrderFormNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.OrderFormNo) + ","); 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("ReqDate" + ","); if (MasterEntity.ReqDate != SystemConfiguration.DateTimeDefaultValue) { MasterValue.Append(SysString.ToDBString(MasterEntity.ReqDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("SaleOPID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.SaleOPID) + ","); MasterField.Append("PBItemCode" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.PBItemCode) + ","); MasterField.Append("PBDensity" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.PBDensity) + ","); MasterField.Append("PBMWidth" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.PBMWidth) + ","); MasterField.Append("PBMWeight" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.PBMWeight) + ","); MasterField.Append("FactoryID2" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.FactoryID2) + ","); MasterField.Append("CPItemCode" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.CPItemCode) + ","); MasterField.Append("CPDensity" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.CPDensity) + ","); MasterField.Append("CPMWidth" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.CPMWidth) + ","); MasterField.Append("CPMWeight" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.CPMWeight) + ","); MasterField.Append("FactoryID3" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.FactoryID3) + ","); MasterField.Append("TecReq" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.TecReq) + ","); MasterField.Append("PBQty" + ","); if (MasterEntity.PBQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.PBQty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("BCPSampleQty" + ","); if (MasterEntity.BCPSampleQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.BCPSampleQty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("PBSampleQty" + ","); if (MasterEntity.PBSampleQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.PBSampleQty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("MakeOPID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.MakeOPID) + ","); MasterField.Append("MakeOPName" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.MakeOPName) + ","); 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("SubmitFlag" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.SubmitFlag) + ","); MasterField.Append("SubmitOPID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.SubmitOPID) + ","); MasterField.Append("SubmitTime" + ","); if (MasterEntity.SubmitTime != SystemConfiguration.DateTimeDefaultValue) { MasterValue.Append(SysString.ToDBString(MasterEntity.SubmitTime.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("DelFlag" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.DelFlag) + ","); MasterField.Append("Remark" + ")"); MasterValue.Append(SysString.ToDBString(MasterEntity.Remark) + ")"); //执行 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 { SaleOrderInstruct MasterEntity = (SaleOrderInstruct)p_Entity; if (MasterEntity.ID == 0) { return(0); } //更新主表数据 StringBuilder UpdateBuilder = new StringBuilder(); UpdateBuilder.Append("UPDATE Sale_SaleOrderInstruct SET "); UpdateBuilder.Append(" ID=" + SysString.ToDBString(MasterEntity.ID) + ","); UpdateBuilder.Append(" FormNo=" + SysString.ToDBString(MasterEntity.FormNo) + ","); UpdateBuilder.Append(" OrderFormNo=" + SysString.ToDBString(MasterEntity.OrderFormNo) + ","); if (MasterEntity.FormDate != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" FormDate=" + SysString.ToDBString(MasterEntity.FormDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" FormDate=null,"); } if (MasterEntity.ReqDate != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" ReqDate=" + SysString.ToDBString(MasterEntity.ReqDate.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" ReqDate=null,"); } UpdateBuilder.Append(" SaleOPID=" + SysString.ToDBString(MasterEntity.SaleOPID) + ","); UpdateBuilder.Append(" PBItemCode=" + SysString.ToDBString(MasterEntity.PBItemCode) + ","); UpdateBuilder.Append(" PBDensity=" + SysString.ToDBString(MasterEntity.PBDensity) + ","); UpdateBuilder.Append(" PBMWidth=" + SysString.ToDBString(MasterEntity.PBMWidth) + ","); UpdateBuilder.Append(" PBMWeight=" + SysString.ToDBString(MasterEntity.PBMWeight) + ","); UpdateBuilder.Append(" FactoryID2=" + SysString.ToDBString(MasterEntity.FactoryID2) + ","); UpdateBuilder.Append(" CPItemCode=" + SysString.ToDBString(MasterEntity.CPItemCode) + ","); UpdateBuilder.Append(" CPDensity=" + SysString.ToDBString(MasterEntity.CPDensity) + ","); UpdateBuilder.Append(" CPMWidth=" + SysString.ToDBString(MasterEntity.CPMWidth) + ","); UpdateBuilder.Append(" CPMWeight=" + SysString.ToDBString(MasterEntity.CPMWeight) + ","); UpdateBuilder.Append(" FactoryID3=" + SysString.ToDBString(MasterEntity.FactoryID3) + ","); UpdateBuilder.Append(" TecReq=" + SysString.ToDBString(MasterEntity.TecReq) + ","); if (MasterEntity.PBQty != 0) { UpdateBuilder.Append(" PBQty=" + SysString.ToDBString(MasterEntity.PBQty) + ","); } else { UpdateBuilder.Append(" PBQty=null,"); } if (MasterEntity.BCPSampleQty != 0) { UpdateBuilder.Append(" BCPSampleQty=" + SysString.ToDBString(MasterEntity.BCPSampleQty) + ","); } else { UpdateBuilder.Append(" BCPSampleQty=null,"); } if (MasterEntity.PBSampleQty != 0) { UpdateBuilder.Append(" PBSampleQty=" + SysString.ToDBString(MasterEntity.PBSampleQty) + ","); } else { UpdateBuilder.Append(" PBSampleQty=null,"); } UpdateBuilder.Append(" MakeOPID=" + SysString.ToDBString(MasterEntity.MakeOPID) + ","); UpdateBuilder.Append(" MakeOPName=" + SysString.ToDBString(MasterEntity.MakeOPName) + ","); 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(" SubmitFlag=" + SysString.ToDBString(MasterEntity.SubmitFlag) + ","); UpdateBuilder.Append(" SubmitOPID=" + SysString.ToDBString(MasterEntity.SubmitOPID) + ","); if (MasterEntity.SubmitTime != SystemConfiguration.DateTimeDefaultValue) { UpdateBuilder.Append(" SubmitTime=" + SysString.ToDBString(MasterEntity.SubmitTime.ToString("yyyy-MM-dd HH:mm:ss")) + ","); } else { UpdateBuilder.Append(" SubmitTime=null,"); } UpdateBuilder.Append(" DelFlag=" + SysString.ToDBString(MasterEntity.DelFlag) + ","); UpdateBuilder.Append(" Remark=" + SysString.ToDBString(MasterEntity.Remark)); 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_BE"></param> private void CheckCorrect(BaseEntity p_BE) { SaleOrderInstruct entity = (SaleOrderInstruct)p_BE; }