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 01-07-2008
pollo_c pollo_c is offline
Miembro
 
Registrado: oct 2006
Posts: 55
Poder: 18
pollo_c Va por buen camino
problemas con parametros

hola amigos les pido una ayuda, tengo un programa para una biblioteca muy simple con cuatro tablas alumnos, libros, prestamos y prestamos_detalle, al correr mi programa no me marca ningún error pero al llegar al siguiente código:

MD.Caux.SQL.Clear;
MD.Caux.SQL.Add('insert into alumnos values (:v1,:v2,:v3,:v4,:v5,:v6');
MD.Caux.Params.Items[0].AsString:=Edit1.Text;
MD.Caux.Params.Items[1].AsString:=Edit2.Text;
MD.Caux.Params.Items[2].AsString:=Edit3.Text;
MD.Caux.Params.Items[3].AsString:=Edit4.Text;
MD.Caux.Params.Items[4].AsString:=Edit5.Text;
MD.Caux.Params.Items[5].AsString:=Edit6.Text;
MD.Caux.ExecSQL();
Donde:
MD =Objeto Modulo de datos.
Caux= objeto Query.
Aparece el siguente error project1.exe raised exceptionclass EDBEEngineError with message ‘ Unexpected en of command. Token:?’
Saben a que se deba este error ?
Espero de su ayuda gracias
Responder Con Cita
  #2  
Antiguo 01-07-2008
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Por lo que veo te falta un paréntesis:

Cita:
Empezado por pollo_c Ver Mensaje
hola amigos les pido una ayuda, tengo un programa para una biblioteca muy simple con cuatro tablas alumnos, libros, prestamos y prestamos_detalle, al correr mi programa no me marca ningún error pero al llegar al siguiente código:

MD.Caux.SQL.Clear;
MD.Caux.SQL.Add('insert into alumnos values (:v1,:v2,:v3,:v4,:v5,:v6)');
MD.Caux.Params.Items[0].AsString:=Edit1.Text;
MD.Caux.Params.Items[1].AsString:=Edit2.Text;
MD.Caux.Params.Items[2].AsString:=Edit3.Text;
MD.Caux.Params.Items[3].AsString:=Edit4.Text;
MD.Caux.Params.Items[4].AsString:=Edit5.Text;
MD.Caux.Params.Items[5].AsString:=Edit6.Text;
MD.Caux.ExecSQL();
Donde:
MD =Objeto Modulo de datos.
Caux= objeto Query.
Aparece el siguente error project1.exe raised exceptionclass EDBEEngineError with message ‘ Unexpected en of command. Token:?’
Saben a que se deba este error ?
Espero de su ayuda gracias
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.

Última edición por marcoszorrilla fecha: 01-07-2008 a las 17:18:26.
Responder Con Cita
  #3  
Antiguo 01-07-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Hola, como te dice Marcos, le falta un parentesis y la comilla debe estar fuera del primer parentesis.

Código Delphi [-]
 MD.Caux.SQL.Add('insert into alumnos values (:v1,:v2,:v3,:v4,:v5,:v6)');

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #4  
Antiguo 02-07-2008
pollo_c pollo_c is offline
Miembro
 
Registrado: oct 2006
Posts: 55
Poder: 18
pollo_c Va por buen camino
hola amigos me sigue marcando mas errores

Hola amigos ya corregí el código del error del paréntesis pero me sigue marcando el siguiente error a la ora de ejecutar el query MD.Caux.ExecSQL; type mismatch in expression amigo ayúdenme a darle una checada a mi código quiero saber si se pueden usar parámetros de la manera que quiero usarlos, si le ven algo raro díganme por favor es que soy muy novato en delphi
Código Delphi [-]
 MD.Caux.SQL.Clear;
   MD.Caux.SQL.Add('insert into alumnos values (:v1,:v2,:v3,:v4,:v5,:v6)');
   MD.Caux.Params.Items[0].AsString:=Edit1.Text;
   MD.Caux.Params.Items[1].AsString:=Edit2.Text;
   MD.Caux.Params.Items[2].AsString:=Edit3.Text;
   MD.Caux.Params.Items[3].AsString:=Edit4.Text;
   MD.Caux.Params.Items[4].AsString:=Edit5.Text;
   MD.Caux.Params.Items[5].AsString:=Edit6.Text;
   MD.Caux.ExecSQL;

Última edición por marcoszorrilla fecha: 02-07-2008 a las 08:25:09.
Responder Con Cita
  #5  
Antiguo 02-07-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Hola pollo_c, si se pueden usar los parametros de la forma que lo estas haciendo, pero también lo puedes hacer utilizando ParamByName de esta forma.

Código Delphi [-]
   MD.Caux.SQL.Clear;
   MD.Caux.SQL.Add('insert into alumnos values (:v1,:v2,:v3,:v4,:v5,:v6)');
   MD.Caux.ParamByName('v1').AsString:=Edit1.Text;
   MD.Caux.ParamByName('v2').AsString:=Edit2.Text;
   MD.Caux.ParamByName('v3').AsString:=Edit3.Text;
   MD.Caux.ParamByName('v4').AsString:=Edit4.Text;
   MD.Caux.ParamByName('v5').AsString:=Edit5.Text;
   MD.Caux.ParamByName('v6').AsString:=Edit6.Text;
   MD.Caux.ExecSQL;

Sobre el error que te marca, el tipo de dato que tienes en alguno de tus campos no esta coincidiendo con lo que le pasas en tus Edits, todos tus campos son String?? , ya que en todos utilizas AsString, que tampoco habría problema si le pasas como cadena el formato que necesita tu campo (Integer, Date....), si tienes diferentes tipos en tu tabla puedes utilizar AsInteger si es entero, AsDateTime (Fecha hora), AsDate (Fecha), AsFloat, AsBoolean......

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
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
Problemas con AdoQuery / Parametros mateamargo SQL 4 18-04-2008 20:50:55
Problemas con query y parametros Petolansa Varios 25 26-11-2007 20:54:46
Problemas con parametros Esau Conexión con bases de datos 1 03-05-2005 15:22:49
Problemas con varios Parametros Carlex SQL 7 13-08-2004 23:34:34
Problemas con parametros pigu SQL 2 13-07-2004 02:29:26


La franja horaria es GMT +2. Ahora son las 13:00:47.


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