Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   C++ Builder (https://www.clubdelphi.com/foros/forumdisplay.php?f=13)
-   -   Ordenar un campo calculado en un DBGrid (https://www.clubdelphi.com/foros/showthread.php?t=81512)

borlandpablo 21-11-2012 10:27:53

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();
}


ecfisa 21-11-2012 18:10:31

Cita:

Empezado por borlandpablo (Mensaje 450052)
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.:)

borlandpablo 23-11-2012 09:36:44

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

Casimiro Noteví 23-11-2012 11:44:24

Cita:

Empezado por borlandpablo (Mensaje 450052)
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 ;)

borlandpablo 24-11-2012 13:12:30

1 Archivos Adjunto(s)
Cita:

Empezado por Casimiro Notevi (Mensaje 450265)
Desde aquí no llegamos a ver tu pantalla para leer el error que te da ;)

En la imagen viene el error. Un saludo.

Casimiro Noteví 24-11-2012 14:11:11

Vale, ¿y qué es 'diasrestantes'? ;)
Porque no has dicho nada sobre eso.

borlandpablo 25-11-2012 13:21:10

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

Casimiro Noteví 25-11-2012 14:31:09

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

borlandpablo 26-11-2012 00:41:52

Pero no aparece en la base de datos, por lo que me da el mismo error.

Un saludo

ecfisa 26-11-2012 02:41:25

Cita:

Empezado por borlandpablo (Mensaje 450497)
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.


La franja horaria es GMT +2. Ahora son las 19:17:11.

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