Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > C++ Builder
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 21-11-2012
borlandpablo borlandpablo is offline
Miembro
NULL
 
Registrado: oct 2012
Posts: 37
Poder: 0
borlandpablo Va por buen camino
Question Ordenar un campo calculado en un DBGrid

Buenas, tengo creado 2 campos calculado en una tabla DBGrid. En el evento OnCellTitle del DBGrid, lo tengo programado para que me ordene por campos, pero cuando lo ordeno por un campo calculado me da error. Os dejo lo que tengo de código:

Código:
void __fastcall TXCatalogos::DBGrid1TitleClick(TColumn *Column)
{
  AnsiString FName = Column->FieldName;
  XDatos->QCatalogos->Close();
  XDatos->QCatalogos->SQL->Text = "SELECT * FROM Catalogo ORDER BY " + FName;
  XDatos->QCatalogos->Open();
}
Responder Con Cita
  #2  
Antiguo 21-11-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por borlandpablo Ver Mensaje
Buenas, tengo creado 2 campos calculado en una tabla DBGrid. En el evento OnCellTitle del DBGrid, lo tengo programado para que me ordene por campos, pero cuando lo ordeno por un campo calculado me da error. Os dejo lo que tengo de código:

Código:
void __fastcall TXCatalogos::DBGrid1TitleClick(TColumn *Column)
{
  AnsiString FName = Column->FieldName;
  XDatos->QCatalogos->Close();
  XDatos->QCatalogos->SQL->Text = "SELECT * FROM Catalogo ORDER BY " + FName;
  XDatos->QCatalogos->Open();
}
Hola borlandpablo.

Y es totalmente lógico ya que el campo no existe en la tabla contra la que efectuas la consulta SQL. Una solución, pero que depende de si tu RDBMS lo permite, es declarar el campo calculado en la creación de la tabla.

Por ejemplo en Firebird:
Código SQL [-]
CREATE TABLE CLIENTES (
  ID        INTEGER NOT NULL,
  APELLIDO  VARCHAR(15)
  NOMBRE    VARCHAR(15),
  APELNOM   COMPUTED BY (APELLIDO || ' ' || NOMBRE),
  ...

Así creada, no tendrías ningún problema en ejecutar la sentencia:
Código SQL [-]
SELECT * FROM CLIENTES
WHERE APELLIDO LIKE 'A%'
ORDER BY APELNOM
Pero desconozco que manejador de bd estés usando y si ofrece esa característica.

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #3  
Antiguo 23-11-2012
borlandpablo borlandpablo is offline
Miembro
NULL
 
Registrado: oct 2012
Posts: 37
Poder: 0
borlandpablo Va por buen camino
Buenas ecfisa, utilizo Access 2010 y lo conecto con el componente ADO. No es exactamente eso lo que busco. Si alguien tiene otra solución se lo agradecería
Responder Con Cita
  #4  
Antiguo 23-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por borlandpablo Ver Mensaje
pero cuando lo ordeno por un campo calculado me da error.
Desde aquí no llegamos a ver tu pantalla para leer el error que te da
Responder Con Cita
  #5  
Antiguo 24-11-2012
borlandpablo borlandpablo is offline
Miembro
NULL
 
Registrado: oct 2012
Posts: 37
Poder: 0
borlandpablo Va por buen camino
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Desde aquí no llegamos a ver tu pantalla para leer el error que te da
En la imagen viene el error. Un saludo.
Imágenes Adjuntas
Tipo de Archivo: jpg Sin título.jpg (28,6 KB, 6 visitas)
Responder Con Cita
  #6  
Antiguo 24-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Vale, ¿y qué es 'diasrestantes'?
Porque no has dicho nada sobre eso.
Responder Con Cita
  #7  
Antiguo 25-11-2012
borlandpablo borlandpablo is offline
Miembro
NULL
 
Registrado: oct 2012
Posts: 37
Poder: 0
borlandpablo Va por buen camino
DiasRestante es un campo calculado que no se encuentra en la base datos. Esta calculado para que me muestre la diferencia entre el la fecha_fin del y el dia de hoy.

Un saludo
Responder Con Cita
  #8  
Antiguo 25-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Quizás puedas ordenarlo por su número, por la posición que ocupa, ejemplo:
Código SQL [-]
select uncampo, doscampos, trescampos, otrocampo, uncampomas
from unatabla
order by 4
Esto ordena por el otrocampo
Responder Con Cita
  #9  
Antiguo 26-11-2012
borlandpablo borlandpablo is offline
Miembro
NULL
 
Registrado: oct 2012
Posts: 37
Poder: 0
borlandpablo Va por buen camino
Pero no aparece en la base de datos, por lo que me da el mismo error.

Un saludo
Responder Con Cita
  #10  
Antiguo 26-11-2012
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por borlandpablo Ver Mensaje
Pero no aparece en la base de datos, por lo que me da el mismo error.

Un saludo
Hola Pablo.

Es que que no que hay darle muchas vueltas, usando una sentencia SQL, es como te dije en el mensaje #2.

Pero parece que Access si permite la creación de campos calculados, revisa este enlace: Agregar un campo calculado a una tabla

Saludos.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
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
Ordenar adoquery por nuevo campo calculado lacovera SQL 7 25-01-2021 09:16:07
ordenar query por un campo calculado???? mguixot SQL 4 24-10-2012 11:00:36
Pasar un campo calculado a un campo del mismo DbGrid maravert Conexión con bases de datos 3 12-05-2006 00:31:30
Ordenar por un campo calculado IVAND SQL 0 24-11-2004 02:17:28
Campo Calculado en DBGrid Agar23 Tablas planas 0 07-11-2003 09:05:50


La franja horaria es GMT +2. Ahora son las 13:57:20.


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