Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-05-2004
JOMABRI JOMABRI is offline
Miembro
 
Registrado: may 2004
Posts: 30
Poder: 0
JOMABRI Va por buen camino
Problema con ClientDataSet y DBexpress

Saludos,

Tengo un ClientDataSet asociado a un TSqlQuery, mediante un TDataSetProvider. El Sql es el siguiente:

select movimiento.*, contrato.codigo
from movimiento, contrato
where movimiento.numero_contrato = contrato.numero_contrato
and contrato.estado = 'A'

Entonces al ClientDataSet se le agregan todos los campos de la tabla MOVIMIENTO y el campo CODIGO de la tabla CONTRATO.

Al adicionar los datos con APPLYUPDATES, aparece el error "COLUMN UNKNOWN contrato.codigo".

Porque aparece este error si en las banderas del proveedor especifiqué que al campo CONTRATO.CODIGO no lo incluyera en la clausula WHERE y que no le hiciera UPDATE, ademas en el evento ONGETTABLENAME del PROVIDER, le asigne la tabla MOVIMIENTO???


Mil gracias.
Responder Con Cita
  #2  
Antiguo 26-05-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Cambia el UpdateMode del Provider, a upWhereChanged o upWhereKeyOnly. (Ahora lo debes tener a upWhereAll).

NOTA: Yo suelo utilizar el upWhereKeyOnly.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #3  
Antiguo 26-05-2004
JOMABRI JOMABRI is offline
Miembro
 
Registrado: may 2004
Posts: 30
Poder: 0
JOMABRI Va por buen camino
Cita:
Empezado por guillotmarc
Hola.

Cambia el UpdateMode del Provider, a upWhereChanged o upWhereKeyOnly. (Ahora lo debes tener a upWhereAll).

NOTA: Yo suelo utilizar el upWhereKeyOnly.

Saludos.
Gracias Guillotmarc, pero sigue saliendo el mismo error.

Coloque los campos llave de tabla con los siguientes banderas en true: UPDATE, WHERE Y KEY, los demás campos de la tabla solo la bandera UPDATE en TRUE, y el campo CONTRA.CODIGO con todas las banderas en FALSE, ademas la propiedad UPDATEMODE del PROVIDER en WHEREKEYONLY.
Responder Con Cita
  #4  
Antiguo 26-05-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Recuerda que los flags hay que ponerlos, no en el ClientDataset, sino en el TSqlQuery al que está conectado el Provider (es decir en el lado Servidor, y no en el lado cliente).

NOTA: Imagino que no estás asignando ningún valor al campo CONTRATO.CODIGO en los nuevos registros.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #5  
Antiguo 26-05-2004
JOMABRI JOMABRI is offline
Miembro
 
Registrado: may 2004
Posts: 30
Poder: 0
JOMABRI Va por buen camino
Cita:
Empezado por guillotmarc
Hola.

Recuerda que los flags hay que ponerlos, no en el ClientDataset, sino en el TSqlQuery al que está conectado el Provider (es decir en el lado Servidor, y no en el lado cliente).

NOTA: Imagino que no estás asignando ningún valor al campo CONTRATO.CODIGO en los nuevos registros.

Saludos.
guillotmarc, al campo CONTRA.CODIGO si le estoy asignando valores.

No le encontre las propiedades de PROVIDERFLAG al TSQLQUERY, el que las tiene es el CLIENTDATASET.
Responder Con Cita
  #6  
Antiguo 26-05-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Pues están ahí. Mira los campos persistentes del TSqlQuery, y verás que todos tienen su ProviderFlags. Además, como te comenté, solo se tienen en cuenta las especificaciones que hagas en los campos del TSqlQuery, las que pongas en los campos de TClientDataset no se utilizan.

No tendrías que poner ningún valor en CONTRA.CODIGO, puesto que no quieres crear/modificar ningún registro en esa tabla. Ya tiene valor.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #7  
Antiguo 26-05-2004
JOMABRI JOMABRI is offline
Miembro
 
Registrado: may 2004
Posts: 30
Poder: 0
JOMABRI Va por buen camino
Cita:
Empezado por guillotmarc
Hola.

Pues están ahí. Mira los campos persistentes del TSqlQuery, y verás que todos tienen su ProviderFlags. Además, como te comenté, solo se tienen en cuenta las especificaciones que hagas en los campos del TSqlQuery, las que pongas en los campos de TClientDataset no se utilizan.

No tendrías que poner ningún valor en CONTRA.CODIGO, puesto que no quieres crear/modificar ningún registro en esa tabla. Ya tiene valor.

Saludos.
Listo GUILLOTMARC, solucionado el problema, muchas gracias, te agradezco mucho.

Saludos y suerte.
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


La franja horaria es GMT +2. Ahora son las 02:51:51.


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