/// <summary> /// 删除 /// </summary> /// <param name="p_Entity">实体类</param> /// <returns>操作影响的记录行数</returns> public override int Delete(BaseEntity p_Entity) { try { YQFormDtsPack MasterEntity = (YQFormDtsPack)p_Entity; if (MasterEntity.ID == 0) { return(0); } //删除主表数据 string Sql = ""; Sql = "DELETE FROM WH_YQFormDtsPack 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); } }
private string GetIDExist(ArrayList p_BE) { string outstr = "0"; for (int i = 0; i < p_BE.Count; i++) { YQFormDtsPack entitydts = (YQFormDtsPack)p_BE[i]; if (entitydts.ID != 0) { outstr += "," + entitydts.ID; } } return(outstr); }
/// <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) { YQFormDtsPack entity = (YQFormDtsPack)p_BE; bool ret = false; string sql = string.Format(" SELECT {0} FROM {1} WHERE 1=1 AND {0}={2} AND {3}<>{4}", p_FieldName, YQFormDtsPack.TableName, SysString.ToDBString(p_FieldValue), "ID", entity.ID); DataTable dt = p_sqlTrans.Fill(sql); if (dt.Rows.Count != 0) { ret = true; } return(ret); }
public void RSave(YQForm p_Entity, YQFormDts[] p_EntityDts, ArrayList list, IDBTransAccess sqlTrans) { try { string sql = string.Empty; sql = "SELECT BoxNo FROM WH_YQFormDtsPack WHERE MainID=" + p_Entity.ID.ToString(); sql += " AND ID NOT IN" + string.Format("({0})", GetIDExist(list)); DataTable dtDelete = sqlTrans.Fill(sql); //删除表结构 if (dtDelete.Rows.Count != 0) //有需要删除的数据 { sql = "DELETE FROM WH_YQFormDtsPack WHERE MainID=" + p_Entity.ID.ToString(); sql += " AND ID NOT IN" + string.Format("({0})", GetIDExist(list)); sqlTrans.ExecuteNonQuery(sql);//删除原单据里应该删除的明细数据,即数据库里有但是UI里已经删除的数据 } for (int i = 0; i < list.Count; i++) { YQFormDtsPack entitydts = (YQFormDtsPack)list[i]; int YQFormdtsdex = -1; for (int m = 0; m < p_EntityDts.Length; m++) { if (p_EntityDts[m].Seq == entitydts.Seq)//找到相同的SEQ了 { YQFormdtsdex = m; break; } } if (YQFormdtsdex == -1)//未找到,异常 { throw new Exception("码单输入异常,未找到单据明细,行号:" + entitydts.Seq); } entitydts.MainID = p_Entity.ID; this.RAdd(p_Entity, p_EntityDts[YQFormdtsdex], entitydts, sqlTrans); } } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
public void RAdd(YQForm p_MainEntity, YQFormDts p_MainDts, BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); YQFormDtsPack entity = (YQFormDtsPack)p_BE; this.RAdd(entity, sqlTrans);//后插入的原因是箱号是在插入箱号实体时生成的 } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 删除 /// </summary> /// <param name="p_BE">要删除的实体</param> /// <param name="sqlTrans">事务类</param> public void RDelete(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); YQFormDtsPack entity = (YQFormDtsPack)p_BE; YQFormDtsPackCtl control = new YQFormDtsPackCtl(sqlTrans); control.Delete(entity); } catch (BaseException) { throw; } catch (Exception E) { throw new BaseException(E.Message); } }
/// <summary> /// 新增(传入事务处理) /// </summary> /// <param name="p_BE">要新增的实体</param> /// <param name="sqlTrans">事务类</param> public void RAdd(BaseEntity p_BE, IDBTransAccess sqlTrans) { try { this.CheckCorrect(p_BE); YQFormDtsPack entity = (YQFormDtsPack)p_BE; YQFormDtsPackCtl control = new YQFormDtsPackCtl(sqlTrans); entity.ID = (int)EntityIDTable.GetID((long)SysEntity.WH_YQFormDtsPack, sqlTrans); control.AddNew(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 { YQFormDtsPack MasterEntity = (YQFormDtsPack)p_Entity; if (MasterEntity.ID == 0) { return(0); } //新增主表数据 StringBuilder MasterField = new StringBuilder(); StringBuilder MasterValue = new StringBuilder(); MasterField.Append("INSERT INTO WH_YQFormDtsPack("); MasterValue.Append(" VALUES("); MasterField.Append("ID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.ID) + ","); MasterField.Append("MainID" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.MainID) + ","); MasterField.Append("Seq" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.Seq) + ","); MasterField.Append("SubSeq" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.SubSeq) + ","); MasterField.Append("PackNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.PackNo) + ","); MasterField.Append("BoxNo" + ","); MasterValue.Append(SysString.ToDBString(MasterEntity.BoxNo) + ","); MasterField.Append("Qty" + ","); if (MasterEntity.Qty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.Qty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("FactQty" + ","); if (MasterEntity.FactQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.FactQty) + ","); } else { MasterValue.Append("null,"); } MasterField.Append("PDQty" + ","); if (MasterEntity.PDQty != 0) { MasterValue.Append(SysString.ToDBString(MasterEntity.PDQty) + ","); } else { MasterValue.Append("null,"); } 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 { YQFormDtsPack MasterEntity = (YQFormDtsPack)p_Entity; if (MasterEntity.ID == 0) { return(0); } //更新主表数据 StringBuilder UpdateBuilder = new StringBuilder(); UpdateBuilder.Append("UPDATE WH_YQFormDtsPack SET "); UpdateBuilder.Append(" ID=" + SysString.ToDBString(MasterEntity.ID) + ","); UpdateBuilder.Append(" MainID=" + SysString.ToDBString(MasterEntity.MainID) + ","); UpdateBuilder.Append(" Seq=" + SysString.ToDBString(MasterEntity.Seq) + ","); UpdateBuilder.Append(" SubSeq=" + SysString.ToDBString(MasterEntity.SubSeq) + ","); UpdateBuilder.Append(" PackNo=" + SysString.ToDBString(MasterEntity.PackNo) + ","); UpdateBuilder.Append(" BoxNo=" + SysString.ToDBString(MasterEntity.BoxNo) + ","); if (MasterEntity.Qty != 0) { UpdateBuilder.Append(" Qty=" + SysString.ToDBString(MasterEntity.Qty) + ","); } else { UpdateBuilder.Append(" Qty=null,"); } if (MasterEntity.FactQty != 0) { UpdateBuilder.Append(" FactQty=" + SysString.ToDBString(MasterEntity.FactQty) + ","); } else { UpdateBuilder.Append(" FactQty=null,"); } if (MasterEntity.PDQty != 0) { UpdateBuilder.Append(" PDQty=" + SysString.ToDBString(MasterEntity.PDQty) + ","); } else { UpdateBuilder.Append(" PDQty=null,"); } 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) { YQFormDtsPack entity = (YQFormDtsPack)p_BE; }