예제 #1
0
        private static COMISSAOTERCEntity FillEntityObject(ref FbDataReader DataReader)
        {
            COMISSAOTERCEntity entity = new COMISSAOTERCEntity();

            FirebirdGetDbData getData = new FirebirdGetDbData();

            entity.IDCOMISSAOTERC = getData.ConvertDBValueToInt32(DataReader, DataReader.GetOrdinal("IDCOMISSAOTERC"));
            entity.IDPEDIDO       = getData.ConvertDBValueToInt32Nullable(DataReader, DataReader.GetOrdinal("IDPEDIDO"));
            entity.IDFUNCIONARIO  = getData.ConvertDBValueToInt32Nullable(DataReader, DataReader.GetOrdinal("IDFUNCIONARIO"));
            entity.PORCENTAGEM    = getData.ConvertDBValueToDecimalNullable(DataReader, DataReader.GetOrdinal("PORCENTAGEM"));
            entity.VALOR          = getData.ConvertDBValueToDecimalNullable(DataReader, DataReader.GetOrdinal("VALOR"));


            return(entity);
        }
예제 #2
0
 private void Grava()
 {
     try
     {
         if (Validacoes())
         {
             CalculaComissao();
             _IDCOMISSAOTERC = COMISSAOTERCP.Save(Entity);
             ListaComissaoTerceiros(_IDPEDIDO);
             Entity = null;
             Util.ExibirMSg(ConfigMessage.Default.MsgSave, "Blue");
         }
     }
     catch (Exception ex)
     {
         MessageBox.Show(ConfigMessage.Default.MsgSaveErro);
         MessageBox.Show("Erro técnico: " + ex.Message);
     }
 }
예제 #3
0
        private void DataGriewDados_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
        {
            int rowindex = e.RowIndex;

            if (LIS_COMISSAOTERCColl.Count > 0 && rowindex > -1)
            {
                int ColumnSelecionada = e.ColumnIndex;
                int CodSelect         = -1;

                if (ColumnSelecionada == 0)//Editar
                {
                    CodSelect = Convert.ToInt32(LIS_COMISSAOTERCColl[rowindex].IDCOMISSAOTERC);
                    Entity    = COMISSAOTERCP.Read(CodSelect);
                }
                else if (ColumnSelecionada == 1)//Excluir
                {
                    DialogResult dr = MessageBox.Show(ConfigMessage.Default.MsgDelete,
                                                      ConfigSistema1.Default.NameSytem, MessageBoxButtons.YesNo);

                    if (dr == DialogResult.Yes)
                    {
                        try
                        {
                            CodSelect = Convert.ToInt32(LIS_COMISSAOTERCColl[rowindex].IDCOMISSAOTERC);
                            COMISSAOTERCP.Delete(CodSelect);
                            ListaComissaoTerceiros(_IDPEDIDO);
                            Entity = null;
                            Util.ExibirMSg(ConfigMessage.Default.MsgDelete2, "Blue");
                        }
                        catch (Exception)
                        {
                            MessageBox.Show(ConfigMessage.Default.MsgDeleteErro);
                        }
                    }
                }
            }
        }
예제 #4
0
        public COMISSAOTERCEntity Read(int IDCOMISSAOTERC)
        {
            FbDataReader reader = null;

            try
            {
                //Verificando a existência de um transação aberta
                if (dbTransaction != null)
                {
                    if (dbCnn.State == ConnectionState.Closed)
                    {
                        dbCnn.Open();
                    }

                    dbCommand             = new FbCommand("Rea_COMISSAOTERC", dbCnn);
                    dbCommand.Transaction = ((FbTransaction)(dbTransaction));
                }
                else
                {
                    if (dbCnn == null)
                    {
                        dbCnn = ((FbConnection)GetConnectionDB());
                    }

                    if (dbCnn.State == ConnectionState.Closed)
                    {
                        dbCnn.Open();
                    }

                    dbCommand             = new FbCommand("Rea_COMISSAOTERC", dbCnn);
                    dbCommand.Transaction = dbCnn.BeginTransaction(IsolationLevel.ReadCommitted);
                }

                dbCommand.CommandType = CommandType.StoredProcedure;

                dbCommand.Parameters.AddWithValue("@IDCOMISSAOTERC", IDCOMISSAOTERC);                //PrimaryKey


                reader = dbCommand.ExecuteReader();

                COMISSAOTERCEntity entity = null;
                if (reader.HasRows)
                {
                    while (reader.Read())
                    {
                        entity = FillEntityObject(ref reader);
                    }
                }

                // Deleta reader
                if (reader != null)
                {
                    reader.Close();
                    reader.Dispose();
                }

                // Fecha conexão
                if (dbTransaction == null)
                {
                    dbCommand.Transaction.Commit();
                    if (dbCnn.State == ConnectionState.Open)
                    {
                        dbCnn.Close();
                    }
                }

                return(entity);
            }
            catch (Exception ex)
            {
                // Deleta reader
                if (reader != null)
                {
                    reader.Close();
                    reader.Dispose();
                }

                if (dbTransaction != null)
                {
                    this.RollbackTransaction();
                }
                else
                {
                    if (dbCommand.Transaction != null)
                    {
                        dbCommand.Transaction.Rollback();
                    }
                    if (dbCnn.State == ConnectionState.Open)
                    {
                        dbCnn.Close();
                    }
                }

                throw ex;
            }
        }
예제 #5
0
        public int Save(COMISSAOTERCEntity Entity)
        {
            int result = 0;

            try
            {
                //Verificando a existência de um transação aberta
                if (dbTransaction != null)
                {
                    if (dbCnn.State == ConnectionState.Closed)
                    {
                        dbCnn.Open();
                    }

                    dbCommand             = new FbCommand("Sav_COMISSAOTERC", dbCnn);
                    dbCommand.Transaction = ((FbTransaction)(dbTransaction));
                }
                else
                {
                    if (dbCnn == null)
                    {
                        dbCnn = ((FbConnection)GetConnectionDB());
                    }

                    if (dbCnn.State == ConnectionState.Closed)
                    {
                        dbCnn.Open();
                    }

                    dbCommand             = new FbCommand("Sav_COMISSAOTERC", dbCnn);
                    dbCommand.Transaction = dbCnn.BeginTransaction(IsolationLevel.ReadCommitted);
                }

                dbCommand.CommandType = CommandType.StoredProcedure;

                //PrimaryKey com valor igual a null, indica um novo registro,
                //o valor da chave será fornecido pelo banco. Qualquer outro valor indicará edição do registro.
                if (Entity.IDCOMISSAOTERC == -1)
                {
                    dbCommand.Parameters.AddWithValue("@IDCOMISSAOTERC", DBNull.Value);
                }
                else
                {
                    dbCommand.Parameters.AddWithValue("@IDCOMISSAOTERC", Entity.IDCOMISSAOTERC);
                }


                if (Entity.IDPEDIDO != null)
                {
                    dbCommand.Parameters.AddWithValue("@IDPEDIDO", Entity.IDPEDIDO);                             //ForeignKey
                }
                else
                {
                    dbCommand.Parameters.AddWithValue("@IDPEDIDO", DBNull.Value);                             //ForeignKey 5
                }
                if (Entity.IDFUNCIONARIO != null)
                {
                    dbCommand.Parameters.AddWithValue("@IDFUNCIONARIO", Entity.IDFUNCIONARIO);                             //ForeignKey
                }
                else
                {
                    dbCommand.Parameters.AddWithValue("@IDFUNCIONARIO", DBNull.Value);             //ForeignKey 5
                }
                dbCommand.Parameters.AddWithValue("@PORCENTAGEM", Entity.PORCENTAGEM);             //Coluna
                dbCommand.Parameters.AddWithValue("@VALOR", Entity.VALOR);                         //Coluna



                //Retorno da Procedure
                FbParameter returnValue;
                returnValue = dbCommand.CreateParameter();

                dbCommand.Parameters["@IDCOMISSAOTERC"].Direction = ParameterDirection.InputOutput;


                //Executando consulta
                dbCommand.ExecuteNonQuery();

                result = int.Parse(dbCommand.Parameters["@IDCOMISSAOTERC"].Value.ToString());


                if (dbTransaction == null)
                {
                    dbCommand.Transaction.Commit();
                    dbCnn.Close();
                }
            }
            catch (Exception ex)
            {
                if (dbTransaction != null)
                {
                    this.RollbackTransaction();
                }
                else
                {
                    if (dbCommand.Transaction != null)
                    {
                        dbCommand.Transaction.Rollback();
                    }
                    if (dbCnn.State == ConnectionState.Open)
                    {
                        dbCnn.Close();
                    }
                }

                throw ex;
            }

            return(result);
        }
예제 #6
0
 private void button1_Click(object sender, EventArgs e)
 {
     Entity = null;
 }