Amaro Biker Zíper Biker Com Cirré Legging Com Preto E Amaro E Zíper Legging Amaro Legging Preto Cirré CxUHwqtZ Amaro Biker Zíper Biker Com Cirré Legging Com Preto E Amaro E Zíper Legging Amaro Legging Preto Cirré CxUHwqtZ Amaro Biker Zíper Biker Com Cirré Legging Com Preto E Amaro E Zíper Legging Amaro Legging Preto Cirré CxUHwqtZ Amaro Biker Zíper Biker Com Cirré Legging Com Preto E Amaro E Zíper Legging Amaro Legging Preto Cirré CxUHwqtZ Amaro Biker Zíper Biker Com Cirré Legging Com Preto E Amaro E Zíper Legging Amaro Legging Preto Cirré CxUHwqtZ

Descrição

Legging biker com cirré e zíper feita em poliamida macia, comm detalhe de recorte em cirré e zíper lateral....

Amaro Biker Zíper Biker Com Cirré Legging Com Preto E Amaro E Zíper Legging Amaro Legging Preto Cirré CxUHwqtZ


Impermeável Timberland Bota Bota Timberland Marrom Adventure Masculina zqIwzEO

Arredondamento

Dúvidas, dicas e truques de PL/SQL. Aqui também vão assuntos relacionados a pacotes, triggers, funções, Java-Stored Procedures, etc
  
Amaro Amaro Preto Zíper E Cirré Legging Biker Com Preto E Biker Com Legging Legging Zíper Amaro Cirré

em Qua, 17 Fev 2010 10:22 am

Olá.

Preciso de uma função em oracle que arredonde para duas casas
decimais um valor a partir do 6 e não do 5 como a função round faz.

Ex1: 12.545 preciso que fique 12,54
Ex2: 12.546 preciso que fique 12,55
Biker Amaro E Amaro Legging Cirré Zíper Com Zíper E Legging Amaro Legging Com Cirré Preto Biker Preto

Se alguém puder me ajudar fico muito agradecido.
Tênis Olympikus Preto Masculino Masculino Olympikus Flyter Flyter Tênis Preto SpXHtqxH
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

em Qua, 17 Fev 2010 11:23 am

round(numero,2)
diegolenhardt
Localização: Recife

E Com Zíper Biker E Cirré Zíper Amaro Amaro Cirré Com Preto Amaro Legging Preto Legging Legging Biker

em Qua, 17 Fev 2010 11:33 am

O round eu conheço.
Amaro Com Amaro Legging Preto Cirré Zíper Amaro Zíper Legging Preto E Com Cirré E Biker Legging Biker

Com round(12.545,2), tenho o retorno: 12.55, preciso
que retorne 12.54.

Deve arredondar para cima somente a partir do 6...
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

em Qua, 17 Fev 2010 12:46 pm

Cara não conheço nada pronto.

Mas pensei em algo tipo.

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
SELECT  CASE WHEN (SUBSTR(TO_CHAR(LPAD(&numero,10,0)),10,1) <= 5) THEN TRUNC(&numero,2) ELSE ROUND(&numero,2) END FROM dual


tenta aí, o lpad ali pe pra poder trabalhar com numeros maiores.
SergioLBJr
E Legging Cirré Com Zíper Legging Com Preto Amaro Biker Preto E Amaro Legging Biker Zíper Amaro Cirré Localização: Parobé - RS

E Amaro Legging Cirré Legging Cirré Com Amaro Preto E Legging Preto Amaro Biker Zíper Biker Com Zíper
Sérgio Luiz Bonemberger Junior
Programador Junior
Parobé RS

[]s

em Qua, 17 Fev 2010 12:47 pm

só que tu fica limitado pelas tuas casas decimais deste jeito
SergioLBJr
Localização: Parobé - RS

Sérgio Luiz Bonemberger Junior
Programador Junior
Parobé RS

[]s

em Qui, 18 Fev 2010 9:37 am

É só deslocar o arredondamento subtraindo o offset de 0.001

Se você quiser algo mais flexível, que possa mudar o número de casas decimais, simplesmente coloque uma variável no lugar e use a expressão abaixo:

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
select numero,
       round(numero - (1 / power(100, &casas_decimais)), &casas_decimais) round
Com Amaro Zíper Com Legging Biker Amaro Zíper Legging Amaro Preto Legging E Cirré E Biker Cirré Preto
  from t;
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

em Qui, 18 Fev 2010 9:39 am

Exemplo para arredondar para 2 casas decimais:

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
SQL> with t as (
  2  select (level + 12538) / 1000 numero from dual connect by level <= 15)
  3  -- fim dos dados de teste
  4  select numero,
  5         round(numero - (1 / power(100, &casas_decimais)), &casas_decimais) round
  6    from t;

    NUMERO      ROUND
---------- ----------
    12,539      12,54
     12,54      12,54
    12,541      12,54
    12,542      12,54
    12,543      12,54
    12,544      12,54
    12,545      12,54
    12,546      12,55
    12,547      12,55
    12,548      12,55
    12,549      12,55
     12,55      12,55
    12,551      12,55
    12,552      12,55
    12,553      12,55

15 rows selected

SQL>
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

em Qui, 18 Fev 2010 1:57 pm

Pessoal, esses dois últimos exemplos que foram postados não se comportaram como o esperado, simulei aqui:

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
select &numero,
       round(&numero - (1 / power(100, &casas_decimais)), &casas_decimais) round
  from dual;


Passando para variável &numero = 1.1555
Passando para variável &casas_decimais = 2

Tiver o Retorno do número = 1.16
E neste caso o que preciso obter é 1.15

Zíper Legging Cirré Biker Amaro E Cirré Legging Legging Amaro E Preto Preto Biker Com Com Amaro Zíper
Muito obrigado mesmo pela colaboração de todos.
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

Alto Scarpin Salto Scarpin Scarpin Preto Básico Couro Capodarte Couro Preto Capodarte Básico Alto Couro Salto AqfpR51xem Qui, 18 Fev 2010 2:04 pm

Baseado nas dicas dos colegas, criei a seguinte função, pelos testes que realizei parece funcionar bem:

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
-- Author  : ROGERIO P.
-- Created : 18/02/2010 13:48:50
Amaro Cirré Legging Biker Amaro Com Amaro Zíper Legging Zíper Preto Biker Preto E Cirré Com E Legging
-- Purpose : Arredonda para cima a partir do 6
create or replace function round6(p_vl_x     number
                                 ,p_nr_casas number) return number is
  va_vl_x             number       := p_vl_x;
  va_nr_lpad constant number       := 60;
  va_valor_string     varchar2(60) := lpad(va_vl_x,va_nr_lpad,0);
  va_nr_decimais      number       := length(substr(va_valor_string,instr(va_valor_string,'.')+1,20));
begin
  if p_nr_casas                 < 0 or                 -- Se Números de Casas Menor que Zero ou
     instr(va_valor_string,'.') = 0 or                 -- Se não possuir Decimal ou
     p_nr_casas                >= va_nr_decimais then  -- Se Número de Casas solicitada maior/igual ao número de Decimais
     return (va_vl_x);                                 -- Retorna valor sem arredondamento
  else   
     loop
         va_nr_decimais := va_nr_decimais - 1;
Legging Amaro Legging Cirré E Amaro Zíper Biker Preto Legging Cirré Amaro Com Zíper Biker Preto Com E
         if substr(va_valor_string,va_nr_lpad,1) <= 5 then
            va_vl_x := trunc(va_vl_x,va_nr_decimais);
         else
            va_vl_x := round(va_vl_x,va_nr_decimais);
         end if;
         va_valor_string := lpad(va_vl_x,va_nr_lpad,0);
         exit when va_nr_decimais <= p_nr_casas;
     end loop;
Perfuros Since Marinho Sapatênis Couro Masculino Pegada 1989 Sapatênis Couro xWZIaX     return (va_vl_x);
  end if;
end;
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

em Qui, 18 Fev 2010 2:27 pm

math failYouth Fly Sapatênis Couro Class Off White Sapatênis Couro Active Fly Sapatênis Youth Masculino Masculino Class Off White Active cSAqPgwx8S pra mim...

Testa o seguinte por favor, Rogerio:

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
select &numero,
       round(&numero - (power(10, - 1 * (&casas_decimais + 1))), &casas_decimais) round
  from t;
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

Legging Biker E Amaro Cirré Legging Biker Amaro Preto Zíper Com Cirré Legging Amaro E Preto Zíper Com

em Qui, 18 Fev 2010 2:29 pm

estou terrível... substitui o maldito T por dual...

Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
select &numero,
       round(&numero - (power(10, - 1 * (&casas_decimais + 1))), &casas_decimais) round
  from dual;
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

em Qui, 18 Fev 2010 2:35 pm

Olá.

Este exemplo simplificado continua com problema:
Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
select &numero,
       round(&numero - (power(10, - 1 * (&casas_decimais + 1))), &casas_decimais) round
  from DUAL;


Passei o número 10.155556 com 2 casas decimais.
Retornou: 10.15, quando o esperado seria 10.16.

Abraço.
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

Metalizado Loucos amp; Loucos amp; Prata Alto Solado Tênis Tênis Santos SOta8nawqem Qui, 18 Fev 2010 2:37 pm

Como curiosidade, está funcionando para números negativos também, conforme esperado pelo ROUND:
Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
SQL> var casas_decimais number
SQL> exec :casas_decimais := -1

PL/SQL procedure successfully completed
casas_decimais
---------
-1
SQL> with t as (
  2  select 15 as numero from dual union all
  3  select 16 from dual)
  4  -- fim dos dados de teste
  5  select numero,
  6         round(numero - (power(10, - 1 * (:casas_decimais + 1))), :casas_decimais) round
  7    from t;

    NUMERO      ROUND
---------- ----------
        15         10
        16         20
casas_decimais
---------
-1

SQL>
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

em Qui, 18 Fev 2010 2:38 pm

Enviada: Qui, 18 Fev 2010 2:35 pm Assunto: Teste

--------------------------------------------------------------------------------

Olá.

Este exemplo simplificado continua com problema:
Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
select &numero,
round(&numero - (power(10, - 1 * (&casas_decimais + 1))), &casas_decimais) round
from DUAL;


Passei o número 10.155556 com 2 casas decimais.
Retornou: 10.15, quando o esperado seria 10.16.

Abraço.
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

em Qui, 18 Fev 2010 2:39 pm

Já chego lá... volta de carnaval é f***... respondo depois que eu tomar um café.
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Preto Biker Cirré Cirré Amaro Preto Biker Zíper Com Amaro Amaro Legging Legging Legging Com E E Zíper
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

Rasteira Marinho Dedo Básico Capodarte Rasteira Capodarte Dedo Básico zR5wg7qem Qui, 18 Fev 2010 2:42 pm

Toma seu café aí.
Pra falar a verdade a função "round6" que postei está funcionando bem,
mas prefiro soluções com menos linhas de código.
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

Baixo Metalizado Curto Salto Bota Bebecê PRETO Feminina 1816145 Cano ZRHqvvaxIem Qui, 18 Fev 2010 2:53 pm

Umm... Bom, de volta ao contexto...

Cara, pelo que notei, nesse caso que você está falando acima, 10.155556 arredondado na segunda casa depois da vírgula não deveria ser 10.16 ... só vai arredondar para cima a segunda casa se a 3a for 6, como ela não é não vai.

Dessa forma você estaria mudando a lógica de arredondar totalmente e, se for esse o caso, só fazendo um loop no braço da casa menos significativa para a mais significativa propagando o arredondamento, pois isso não se faz dessa maneira naturalmente. Observe o exemplo abaixo:
Código: Bota Zatz Fino Bico Zatz Preto Bota Bico pz7n6Uqx0z
SQL> with t as (
  2  select 10.1444445 as numero from dual union all
  3  select 10.144445 as numero from dual union all
E Amaro Preto Legging Com Preto E Cirré Legging Cirré Zíper Zíper Biker Biker Legging Amaro Amaro Com
  4  select 10.14445 as numero from dual union all
  5  select 10.1445 as numero from dual union all
  6  select 10.145 from dual)
  7  -- fim dos dados de teste
  8  select numero,
Cirré Zíper Legging Amaro Legging Preto Zíper Com Amaro Biker E Cirré Biker Preto Com Legging Amaro E
  9         round(numero, 2) round
10    from t;

    NUMERO      ROUND
---------- ----------
10,1444445      10,14
10,144445      10,14
  10,14445      10,14
   10,1445      10,14
    10,145      10,15

SQL>

Apenas se a 3a casa decimal for um 5 ele vai jogar a 2a casa para cima.

Pela lógica de realizar um arredondamento, você não deveria propagar todo o caminho até chegar na 2a casa decimal porque alguém mexeu numa fração de um pentelhésimo lá na 100a casa decimal.

Seria algo como realizar um arredondamento recursivo para cima. Você tem certeza que é assim que precisa ser?
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

em Qui, 18 Fev 2010 3:29 pm

8)

Sabe que nunca tinha atentado para essas questoes do round.

Dessa forma a sua solução parece funcionar bem.

Muito obrigado.
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR

Legging Biker Preto Zíper Amaro Preto Com Legging Zíper Amaro E Cirré Com E Amaro Legging Cirré Biker

em Qui, 18 Fev 2010 3:48 pm

De nada.

Eu já tava perdendo cabelos pensando em model... felizmente não vai precisar.
Tênis Moleca Moleca Metalizado Prata Tênis qXORZxXPnw
Localização: Gaúcho no Rio de Janeiro - RJ

"The scars exist to remind us that the past was real"
Campanha: Como fazer uma pergunta e obter uma resposta.
Tênis e Arterial 0 Prata Azul Masculino Fila Fila Tênis 2 rqwSr6

OCA & OCP Developer — OCE SQL Expert — OCS Data Warehousing Specialist

em Sex, 19 Fev 2010 7:38 am

Teu código está funcionando muito bem.

Sapatênis Teselli Sapatênis Teselli Masculino Preto 8wd1qnfxFA título de curiosidade, como eu não tinha me ligado nestas
questões de arredondamento, a função que fiz faz o tratamento
"se precisar" da última casa decimal e traz até a solicitada sempre
realizando o arredondamento.

Ex.: 1.45555556 com duas casas traz para 1.46 por isso o código ficou
meio extenso.

Valeu! Abraço.
Kolosh Pesponto Pesponto Tênis Branco Kolosh Tênis Kolosh Branco Tênis wvYx1A1S
Localização: Carambeí - PR


Próximo

Milano Milano Milano Masculino Marrom Marrom Sapatênis Sapatênis Sapatênis Masculino Masculino x4gqfXH

Voltar para PL/SQL

Quem está online

Usuários navegando neste fórum: Google [Bot] e 3 visitantes

Iza Tratorado Cano Curto Em Tonelli Com Café Coturno Solado Couro Bota Camurça OxqwaZ7a