Пример #1
0
        public static string GravarCondPgto(TRegistro_CadCondPgto val, BancoDados.TObjetoBanco banco)
        {
            bool            st_transacao = false;
            TCD_CadCondPgto qtb_cond     = new TCD_CadCondPgto();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_cond.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_cond.Banco_Dados = banco;
                }
                val.Cd_condpgto = CamadaDados.TDataQuery.getPubVariavel(qtb_cond.GravarCondPgto(val), "@P_CD_CONDPGTO");
                val.lCondParcDel.ForEach(p => TCN_CadCondPgto_X_Parcelas.DeletarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados));
                val.lCondPgto_X_Parcelas.ForEach(p =>
                {
                    p.Cd_condpgto = val.Cd_condpgto;
                    TCN_CadCondPgto_X_Parcelas.GravarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados);
                });
                if (st_transacao)
                {
                    qtb_cond.Banco_Dados.Commit_Tran();
                }
                return(val.Cd_condpgto);
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_cond.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro gravar condicao: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_cond.deletarBanco_Dados();
                }
            }
        }
Пример #2
0
        public static string DeletarCondPgto(TRegistro_CadCondPgto val, BancoDados.TObjetoBanco banco)
        {
            bool            st_transacao = false;
            TCD_CadCondPgto qtb_cond     = new TCD_CadCondPgto();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_cond.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_cond.Banco_Dados = banco;
                }
                val.lCondParcDel.ForEach(p => TCN_CadCondPgto_X_Parcelas.DeletarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados));
                val.lCondPgto_X_Parcelas.ForEach(p => TCN_CadCondPgto_X_Parcelas.DeletarCondPgto_X_Parcelas(p, qtb_cond.Banco_Dados));
                qtb_cond.DeletarCondPgto(val);
                if (st_transacao)
                {
                    qtb_cond.Banco_Dados.Commit_Tran();
                }
                return("OK");
            }
            catch
            {
                if (st_transacao)
                {
                    qtb_cond.Banco_Dados.RollBack_Tran();
                }
                val.St_registro = "C";//Cancelado
                return(GravarCondPgto(val, null));
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_cond.deletarBanco_Dados();
                }
            }
        }