![]() |
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- |
Cita:
Otra cosa, ¿De qué tipo y cómo está definido el campo BLOB? ¿Cómo lo rellenas? |
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 |
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 |
Cita:
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. :) |
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 |
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 |
Cita:
|
La franja horaria es GMT +2. Ahora son las 23:32:16. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi