예제 #1
0
        public static void GravarDesdobroContratoXPedidoItem(TList_CadContratoxPedidoItem val, TObjetoBanco banco)
        {
            bool st_transacao = false;
            TCD_CadContratoxPedidoItem qtb_reg = new TCD_CadContratoxPedidoItem();

            try
            {
                if (banco == null)
                {
                    st_transacao = qtb_reg.CriarBanco_Dados(true);
                }
                else
                {
                    qtb_reg.Banco_Dados = banco;
                }
                val.ForEach(p =>
                {
                    //Excluir desdobros
                    p.lDesdEspecialDel.ForEach(v => TCN_ContratoItem_X_DesdEspecial.Excluir(v, qtb_reg.Banco_Dados));
                    //Inserir/Alterar desdobros
                    p.lDesdEspecial.ForEach(v =>
                    {
                        v.Nr_contratoorig   = p.Nr_contrato;
                        v.Nr_pedidoorig     = p.Nr_pedido;
                        v.Cd_produtoorig    = p.Cd_produto;
                        v.Id_pedidoitemorig = p.Id_pedidoitem;
                        TCN_ContratoItem_X_DesdEspecial.Gravar(v, qtb_reg.Banco_Dados);
                    });
                });
                if (st_transacao)
                {
                    qtb_reg.Banco_Dados.Commit_Tran();
                }
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_reg.Banco_Dados.RollBack_Tran();
                }
                throw new Exception("Erro gravar desdobro: " + ex.Message.Trim());
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_reg.deletarBanco_Dados();
                }
            }
        }
예제 #2
0
        public static string DeletarContratoxPedidoItem(TRegistro_CadContratoxPedidoItem val, TObjetoBanco banco)
        {
            bool st_transacao = false;
            TCD_CadContratoxPedidoItem qtb_ContratoxPedidoItem = new TCD_CadContratoxPedidoItem();

            try
            {
                if (banco == null)
                {
                    qtb_ContratoxPedidoItem.CriarBanco_Dados(true);
                    st_transacao = true;
                }
                else
                {
                    qtb_ContratoxPedidoItem.Banco_Dados = banco;
                }
                //Deletar Item Contrato
                qtb_ContratoxPedidoItem.DeletarContratoxPedidoItem(val);
                //A Stored Procedure ira excluir os desdobros automaticamente
                if (st_transacao)
                {
                    qtb_ContratoxPedidoItem.Banco_Dados.Commit_Tran();
                }
                return("OK");
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_ContratoxPedidoItem.Banco_Dados.RollBack_Tran();
                }
                throw new Exception(ex.Message);
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_ContratoxPedidoItem.deletarBanco_Dados();
                }
            }
        }
예제 #3
0
        public static string DeletarTodosContratoxPedidoItem(decimal nr_pedido, TObjetoBanco banco)
        {
            bool st_transacao = false;
            TCD_CadContratoxPedidoItem qtb_ContratoxPedidoItem = new TCD_CadContratoxPedidoItem();

            try
            {
                if (banco == null)
                {
                    qtb_ContratoxPedidoItem.CriarBanco_Dados(true);
                    st_transacao = true;
                }
                else
                {
                    qtb_ContratoxPedidoItem.Banco_Dados = banco;
                }
                //Deletar Itens do Contrato
                qtb_ContratoxPedidoItem.DeletarTodosContratoxPedidoItem(nr_pedido);
                if (st_transacao)
                {
                    qtb_ContratoxPedidoItem.Banco_Dados.Commit_Tran();
                }
                return("OK");
            }
            catch (Exception ex)
            {
                if (st_transacao)
                {
                    qtb_ContratoxPedidoItem.Banco_Dados.RollBack_Tran();
                }
                throw new Exception(ex.Message);
            }
            finally
            {
                if (st_transacao)
                {
                    qtb_ContratoxPedidoItem.deletarBanco_Dados();
                }
            }
        }