Si usas CDS lo que tenes que abrir o cerrar es el CDS no el Query.
Yo Uso los CDS asociados con DataSetProvider y este con un Query. Cuando tengo que hacer un cambio en el SQL, lo que hago en la propiedad del CommandText del CDS Reescribo la santencia SQL, para ello la propiedad del DSP que dice poAllowCommandText:=True.
A mi me anda de pelos..
|