public static string Gravar(TRegistro_LocTerceiro val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_LocTerceiro qtb_locacao = new TCD_LocTerceiro(); try { if (banco == null) { st_transacao = qtb_locacao.CriarBanco_Dados(true); } else { qtb_locacao.Banco_Dados = banco; } //Itens val.Id_locstr = CamadaDados.TDataQuery.getPubVariavel(qtb_locacao.Gravar(val), "@P_ID_LOC"); val.lItensDel.ForEach(p => TCN_ItensLocTerceiro.Excluir(p, qtb_locacao.Banco_Dados)); val.lItens.ForEach(p => { if (val.St_registro.ToUpper().Equals("E")) { p.Dt_fin = CamadaDados.UtilData.Data_Servidor(); } p.Id_loc = val.Id_loc; p.Cd_empresa = val.Cd_empresa; TCN_ItensLocTerceiro.Gravar(p, qtb_locacao.Banco_Dados); }); if (st_transacao) { qtb_locacao.Banco_Dados.Commit_Tran(); } return(val.Id_locstr); } catch (Exception ex) { if (st_transacao) { qtb_locacao.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro gravar locacao: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_locacao.deletarBanco_Dados(); } } }
public static string Excluir(TRegistro_LocTerceiro val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_LocTerceiro qtb_loc = new TCD_LocTerceiro(); try { if (banco == null) { st_transacao = qtb_loc.CriarBanco_Dados(true); } else { qtb_loc.Banco_Dados = banco; } //Exclusão Lógica val.St_registro = "C"; qtb_loc.Gravar(val); val.lItens.ForEach(p => TCN_ItensLocTerceiro.Excluir(p, qtb_loc.Banco_Dados)); if (st_transacao) { qtb_loc.Banco_Dados.Commit_Tran(); } return("OK"); } catch (Exception ex) { if (st_transacao) { qtb_loc.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro excluir locacao: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_loc.deletarBanco_Dados(); } } }