Utilizamos cookies propias y de terceros. Al navegar entendemos que aceptas el uso de cookies. +Info.
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Usuario
· Wiki

Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error: Can not execute query, undefined key fields
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error: Can not execute query, undefined key fields

Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error: Can not execute query, undefined key fields Responder citando

Estoy utilizando el componente NC OCI8 para acceso a base de datos Oracle con Delphi 6. Las consultas de selección (SELECT) las realizo sin problemas. El problema surge cuando quiero mostrar el resultado de una consulta en un Grid y permitir que sea modificable directamente. Cuando intento validar con:

nombreQuery.ApplyUpdates;

Me aparece este error:

OCIUpdateSQL1: NOE129/Q - Can not execute query, undefined key fields.

¿a qué se puede deber? ¿qué estoy haciendo mal?

He probado a enlazar el componente TOCIQuery con el TOCIUpdateSQL, pero me sigue dando el mismo error.
MensajePublicado:
Vie Oct 13, 2006 10:28 am
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error: "Can not execute query, undefined key fields Responder citando



Anuncios



Para que una consulta SQL realizada con el componente TOCIQuery sea modificable es necesario que este componente esté enlazado con el componente TOCIUpdateSQL por la propiedad UpdateObject del componente TOCIQuery. Pero, además, este componente necesita que haya una columna (campo) en el select que sea identificable como clave primaria de la consulta (identificador único). Para resolver tu problema añade a la consulta el campo "rowid" que Oracle utiliza como dirección física del registro, con lo cual es único en toda la base de datos.

Un ejemplo:

select tt.diacitacion, tt.rowid, tc.referencia, tc.interesado, tc.fecha
from citacion tt, tablaanexa tp, tablaconsulta tc
where tp.clave = tt.clave and tp.clave=tc.clave
MensajePublicado:
Vie Oct 13, 2006 10:49 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A