Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Ordenar con cadenas con acentos en Oracle
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Ordenar con cadenas con acentos en Oracle

Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Ordenar con cadenas con acentos en Oracle Responder citando

He estado haciendo comprobaciones y cuando ordeno una consulta SQL por una fila que contiene acentos me devuelve resultados ilógicos, por ejemplo:

Estos tres valores, por lógica para el usuario, debería ordenarlos así:
Esto está aaaa
Esto esta aaaa
Esto está bien
Esto esta bien
Esto está mal
Esto esta mal


En cambio, los ordena así:
Esto está aaaa
Esto está bien
Esto está mal
Esto esta aaaa
Esto esta bien
Esto esta mal


Parece ser que tienen "mayor" valor las palabras acentuadas.

¿Se puede solucionar esto?
MensajePublicado:
Mar Sep 30, 2008 5:12 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Ordenar con cadenas con acentos en Oracle Responder citando



Anuncios



varios escribió:
He estado haciendo comprobaciones y cuando ordeno una consulta SQL por una fila que contiene acentos me devuelve resultados ilógicos, por ejemplo:

Estos tres valores, por lógica para el usuario, debería ordenarlos así:
Esto está aaaa
Esto esta aaaa
Esto está bien
Esto esta bien
Esto está mal
Esto esta mal


En cambio, los ordena así:
Esto está aaaa
Esto está bien
Esto está mal
Esto esta aaaa
Esto esta bien
Esto esta mal


Parece ser que tienen "mayor" valor las palabras acentuadas.

¿Se puede solucionar esto?



Efectivamente, si nos creamos una tabla con
Código:

create table prueba (campo varchar(100));


E insertarmos los registros que nos comentas:
Código:

insert into prueba values ('Esto está bien');
.....


Si hacemos un:

Código:

select * from prueba order by 1;

Nos devolverá los resultados como nos comentas. Efectivamente, para Oracle:

Á > á > a > A

Con lo cual no te ordenará de forma "lógica" para el usuario un campo con estos valores.

Para solucionarlo puedes hacer varias cosas, una de ellas es traducir los valores del campo y quitarles los acentos con las funciones de Oracle UPPER y TRANSLATE, sería algo así:
Código:

select UPPER(TRANSLATE(campo,'ÁÉÍÓÚáéíóú','AEIOUAEIOU'))
from prueba
order by 1


Devolverá los valores correctamente ordenados (sin tener en cuenta mayúsculas ni acentos):
ESTO ESTA AAAA
ESTO ESTA AAAA
ESTO ESTA BIEN
ESTO ESTA BIEN
ESTO ESTA MAL
ESTO ESTA MAL
MensajePublicado:
Mar Sep 30, 2008 5:19 pm
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Oracle Database, motor de base de datos profesional  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A