Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 30-09-2010
goduquez goduquez is offline
Miembro
 
Registrado: mar 2007
Posts: 24
Poder: 0
goduquez Va por buen camino
Caracteres Chinos ¿de donde salieron?

Saludos...

Tengo un problemita que me surgió...
En una consulta que realizo con un TIBQuery, uno de los campos es de tipo BLOB en texto, pero me retorna unos caracteres chinos, llevo días con esto y no veo la solución.

Amplío detalles:

Los varchar no presentan problemas.
El campo memo lo veo bien desde el IBExpert.
El conjunto de caracteres todos lo tienen definido en "none"
uso delphi 2010
firebird 2.5

Muchas gracias por sus sugerencias-
Responder Con Cita
  #2  
Antiguo 30-09-2010
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.281
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por goduquez Ver Mensaje
En una consulta que realizo con un TIBQuery, uno de los campos es de tipo BLOB en texto, pero me retorna unos caracteres chinos, llevo días con esto y no veo la solución.
Una pregunta, para aclarar las cosas. Cuando dices "caracteres chinos", ¿Te refieres a "caracteres chinos" de verdad o a lo que coMúnmente llamamos "marcianadas", es decir, caracteres sin sentido?

Otra cosa, ¿De qué tipo y cómo está definido el campo BLOB?
¿Cómo lo rellenas?
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 30-09-2010
goduquez goduquez is offline
Miembro
 
Registrado: mar 2007
Posts: 24
Poder: 0
goduquez Va por buen camino
Gracias por tu interes..
Si por lo que veo son cararcteres chinos o de lengua asiatica.

El campo lo tengo definido asi:

A_DESCRIPCION BLOB SUB_TYPE 1 SEGMENT SIZE 8

La inserción la tengo asi:

ParamByName('descrip').AsString:=E4.Lines.Text; //parámetro que pasa

Lo he llenado con IBExpert dierctamente, y la consulta retorna con el mismo problema.

Gracias
Responder Con Cita
  #4  
Antiguo 01-10-2010
goduquez goduquez is offline
Miembro
 
Registrado: mar 2007
Posts: 24
Poder: 0
goduquez Va por buen camino
Machacando encontré una solución parcial.

El problema lo presenta el componente TIBQuery de la versión de Delphi 2010, cuando llama el campo de tipo Blob en la BD, crea el objeto asociado al campo Blob de tipo TWideMemoField, adiferencia de Delphi 7 (que tenía antes) lo creaba de tipo TMemoField.

El problema que me queda es que debo retocar cada consulta que contenga un Blob Texto....y no deseo esto.

¿Alguna idea?

Gracias
Responder Con Cita
  #5  
Antiguo 01-10-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Cita:
Empezado por goduquez Ver Mensaje
[...] crea el objeto asociado al campo Blob de tipo TWideMemoField, adiferencia de Delphi 7 (que tenía antes) lo creaba de tipo TMemoField.

El problema que me queda es que debo retocar cada consulta que contenga un Blob Texto....y no deseo esto.

¿Alguna idea?
Puede que baste con cambiar la propiedad Transliterate del campo.

También tienes la opción de ajustar los valores en el arreglo global DefaultFieldClasses, aunque no considero que sea una buena solución.

Prueba y comenta cómo te fue.

Saludos.

Al González.
Responder Con Cita
  #6  
Antiguo 04-10-2010
goduquez goduquez is offline
Miembro
 
Registrado: mar 2007
Posts: 24
Poder: 0
goduquez Va por buen camino
Gracias González por tu interes.

No aplica por lo que la propiedad Transliterate , es del campo ya creado. y si creo el campo previamente... lo creo del tipo TMemoField y no hay problema.
El problema surge cuando tenemos un mismo componente TIBQuery para diferentes consultas. éste crea los campos dinámicamente en la ejecución y es cuando se presenta el problema expuesto.

El objeto principal es como controlar este proceso (de creación de los campos) de acuerdo al tipo de campo retornado por la consulta.

Saludos

Gabriel
Responder Con Cita
  #7  
Antiguo 04-10-2010
goduquez goduquez is offline
Miembro
 
Registrado: mar 2007
Posts: 24
Poder: 0
goduquez Va por buen camino
Con esto creo que damos por terminado este hilo.

La solución es adicionar en la coneccion el sets de caracteres, para ser usado correctamente el TWideMemoField, en mi caso es "lc_ctype=ISO8859_1",
quedando la coneccion a l a DB así:

user_name=sysdba
password=masterkey
lc_ctype=ISO8859_1

Gracias por el interes prestado.

Un abrazo

Gabriel
Responder Con Cita
  #8  
Antiguo 04-10-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Cita:
Empezado por goduquez Ver Mensaje
La solución es adicionar en la coneccion el sets de caracteres, para ser usado correctamente el TWideMemoField, en mi caso es "lc_ctype=ISO8859_1",
quedando la coneccion a l a DB así:

user_name=sysdba
password=masterkey
lc_ctype=ISO8859_1

Gracias por el interes prestado.

Un abrazo

Gabriel
De nada, Gabriel, para eso estamos en este club. Me alegro de que lo hayas solucionado agregando el conjunto de caracteres en los parámetros de la conexión.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Caracteres chinos en aplicación Cmmv Varios 8 07-10-2010 13:20:40
Caracteres chinos en Firebird erickahr Firebird e Interbase 4 01-04-2010 23:36:32
Uno de chinos FGarcia Humor 0 27-08-2008 17:51:12
&%#%!= Chinos!! AzidRain La Taberna 11 01-07-2008 07:45:18
Chinos barman Humor 5 13-09-2003 19:01:42


La franja horaria es GMT +2. Ahora son las 23:12:42.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi