StringGrid Concatenar Celdas
Estimados, tengo una pequeño problema en un proyecto en el cual debo crear un frontend para escritorio de una sistema web en el cual uno de los principales requisitos es no modificar la estructura de la BD.
Hasta el momento todo ok pero me tope con el siguiente problema: Las BD tienen los nombres de los usuarios/clientes, apellido paterno y materno guardados en distintos campos y en la aplicación web cuando se muestran los usuarios aparecen en la columna "nombres" (que solo tiene el o los nombres en la BD) con nombre y apellidos concatenados, necesitan que se vea igual en la versión de escritorio. Generalmente utilizo este código en el evento StringGrid1DrawColumnCell para hacer algo similar en el mismo sistema (funciona perfecto):
He tratado de cambiar el código para que me permita poder cambiar la celda nombre por la concatenación de Nombre, apellido Paterno y Materno y no logro hacerlo, de antemano agradezco cualquier ayuda, quedo atento a sus comentarios, saludos. Utilizo XE7, MySQL, Firemonkey, Query y StringGrid. |
Hola Lenny.
La verdad es que no sé si terminé de comprender claramente la situación... De lo que entendí, no veo que relación pueda tener el evento OnDrawColumnCell con lo que buscas hacer. Si deseas mostrar la unión de nombre-apellido en una columna, podes hacerlo al momento de cargar el TStringGrid desde la tabla de tu bd. Un ejemplo de lo que te digo con la tabla CLIENTS que trae Delphi de facto: Si deseas realizar la concatenación desde Delphi, reemplaza estas líneas:
Resultado del ejemplo: Saludos :) |
O si usas algun componente Query para acceder a los datos, podes traerte el nombre completo de la BD
Ejemplo que yo uso en Firebird:
Por supuesto despues debes usar el "nuevo campo" 'NombreCompleto'
Deberias buscar como concatenar strings en MySQL, cada motor podria tener distinta sintaxis Saludos |
Estimados, ninguno de los 2 ejemplos me sirvió, el de ecfisa con error y es por que estoy trabajando con Firemonkey, el de AgutinOrtu en teoría debería funcionar, lo edite según mis necesidades pero me lanza error preguntando por el primer registro "Field 'IDUSUARIO' not found" siendo que en ningún lado hago referencia a el.
Me explico mejor, necesito de una tabla llamada "usuario" concatenar las columnas "nombres", apellido "paterno" y "materno", todo esto en un StrinGrid, por que? por que el cliente tiene una sistema web (JAVA) y quiere un frontend para escritorio y quiere que al menos las ventanas que mas usan (en este caso usuarios) se vean como en la web, donde la columna "nombres" muestra el nombre completo del usuario. El problema principal es que uno de los requisitos mas importantes es trabajar con la base de datos como esta, sin agregar, cambiar menos quitar algo de la BD lo cual dificulta un poco el proyecto. ¿Por que en el evento OnDrawColumnCell? En algún momento (como ahora) me toco cambiar los colores de ciertas celdas que cumplan X condición, con el tiempo necesite hacer lo mismo pero en ves de cambiar el color cambiar los textos si cumplían cierta condición (True / False), por ejemplo un checkbox que en ves de aparecer 0 / 1 aparezca Activado / Desactivado en el StrinGrid. Como modifique el mismo código que estaba en OnDrawColumnCell y me funciono lo seguí usando de esa manera (hasta ahora) y nunca he tenido problemas. ¿Por que StrinGrid y la petición? El cliente quiere ver todos los usuarios como en la web (en una lista) y Firemonkey solo tiene Grid y StringGrid. Espero haber aclarado un poco mas mi problema, si necesitan mas detalles o explicar algo mas estaré pendiente, de antemano muchas gracias. |
El codigo de ecfisa te genera un error? Cual es?
Si te sale en algun lado que no encuentra un campo es porque "no se lo estas dando" Estas usando LiveBindings? |
Como comente antes utilizo Firemonkey, en VCL funciona perfecto por eso el error, me a pasado con varios códigos que tuve que rehacer pero en este caso simplemente el componente StringGrid no soporta ciertas características que vienen en el código, saludos y gracias.
PD: si, estoy usando LiveBindings (Firemonkey). |
Solucionado
estimados, muchísimas gracias por la ayuda, a pura prueba y error y con lo dicho ya lo solucione:
los primeros 2 IF cambian en el StringGrid los valores True / Fals por Si / NO (puede ser cualquier otro valor, Activado / Desactivado, etc.) y la ultima linea hace lo que necesito, cargar en el StrinGrid en la columna "Nombres" la concatenación del nombres y apellido del usuario cumpliendo con los requisitos de no tocar la estructura de la base de datos. Solo me queda saber si existe una forma mas elegante y no tan artesanal de hacer esto, y donde mas aparte de DrawColumnCell puedo colocar el código, ya que no me sirve en el Form.Create por si se actualizan los datos. Gracias por la ayuda y quedo atento a sus comentarios!. |
Creo que podes asignar dinámicamente a tu fuente de datos, en el campo Nombre, un manejador en el evento OnGetText
Por ejemplo defino esto en la sección private del form
La asignación dinámica
Y la implementación
Luego con LiveBindigs te recomiendo revisar aca El evento que usaste, OnDrawCell yo lo dejaría para manejar el aspecto visual del grid en si, es decir, fuente, color de fondo, etc |
Hola Lenny.
Debo reconocer que no leí (o se me pasó) "Firemonkey" al leer el mensaje :o Cita:
Saludos :) |
La franja horaria es GMT +2. Ahora son las 19:55:00. |
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