public static string Gravar(TRegistro_TanqueCombustivel val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_TanqueCombustivel qtb_tanque = new TCD_TanqueCombustivel(); try { if (banco == null) { st_transacao = qtb_tanque.CriarBanco_Dados(true); } else { qtb_tanque.Banco_Dados = banco; } val.Id_tanquestr = CamadaDados.TDataQuery.getPubVariavel(qtb_tanque.Gravar(val), "@P_ID_TANQUE"); if (val.St_registro.Trim().ToUpper().Equals("C")) { //Cancelar todos os bicos amarrados ao tanque TCN_BicoBomba.Buscar(string.Empty, string.Empty, val.Cd_empresa, val.Id_tanquestr, "'A'", qtb_tanque.Banco_Dados).ForEach(p => { p.St_registro = "C"; TCN_BicoBomba.Gravar(p, qtb_tanque.Banco_Dados); }); } if (st_transacao) { qtb_tanque.Banco_Dados.Commit_Tran(); } return(val.Id_tanquestr); } catch (Exception ex) { if (st_transacao) { qtb_tanque.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro gravar tanque: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_tanque.deletarBanco_Dados(); } } }
public static string Excluir(TRegistro_TanqueCombustivel val, BancoDados.TObjetoBanco banco) { bool st_transacao = false; TCD_TanqueCombustivel qtb_tanque = new TCD_TanqueCombustivel(); try { if (banco == null) { st_transacao = qtb_tanque.CriarBanco_Dados(true); } else { qtb_tanque.Banco_Dados = banco; } if (new TCD_BicoBomba(qtb_tanque.Banco_Dados).BuscarEscalar( new Utils.TpBusca[] { new Utils.TpBusca() { vNM_Campo = "a.id_tanque", vOperador = "=", vVL_Busca = val.Id_tanquestr } }, "1") != null) { val.St_registro = "C"; qtb_tanque.Gravar(val); //Cancelar todos os bicos amarrados ao tanque TCN_BicoBomba.Buscar(string.Empty, string.Empty, val.Cd_empresa, val.Id_tanquestr, "'A'", qtb_tanque.Banco_Dados).ForEach(p => { p.St_registro = "C"; TCN_BicoBomba.Gravar(p, qtb_tanque.Banco_Dados); }); } else { qtb_tanque.Excluir(val); } if (st_transacao) { qtb_tanque.Banco_Dados.Commit_Tran(); } return(val.Id_tanquestr); } catch (Exception ex) { if (st_transacao) { qtb_tanque.Banco_Dados.RollBack_Tran(); } throw new Exception("Erro excluir tanque: " + ex.Message.Trim()); } finally { if (st_transacao) { qtb_tanque.deletarBanco_Dados(); } } }