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 17-02-2009
tebre tebre is offline
Miembro
 
Registrado: nov 2008
Posts: 93
Poder: 16
tebre Va por buen camino
Insertar valores...Error

necesito ayuda de como insertar estos datos en un base de dato SQL Server 2005

Código Delphi [-]
 
procedure TFrmSolicitud.BtnAgregarClick(Sender: TObject);
var global : integer;
begin
   global :=0;
   boleano:=false;
        //*********Ingresar en la tabla Principal********* 
         Datos.QrySolicitud.Active:= False;
         Datos.QrySolicitud.SQL.Clear;
         Datos.QrySolicitud.SQL.Add('INSERT INTO Solicitud VALUES(');
         Datos.QrySolicitud.SQL.Add(Quotedstr(EdFolioSolicitud.Text) + ',');
         Datos.QrySolicitud.SQL.Add(Quotedstr(LblUsuarioCreador.Caption) + ',');
         Datos.QrySolicitud.SQL.Add(dateToStr(DtpFechaCreacion.Date) + ',');  //insertar dato tipo fecha
         Datos.QrySolicitud.SQL.Add(dateToStr(DtpFechaCreacion.Date) + ',');   //insertar dato tipo fecha
         Datos.QrySolicitud.SQL.Add(dateToStr(DtpFechaCreacion.Date) + ',');  //insertar dato tipo fecha
         Datos.QrySolicitud.SQL.Add(Quotedstr(Boleano) + ','); // Inserta este dato en un campo Boolan
         Datos.QrySolicitud.SQL.Add(Quotedstr(Boleano) + ','); // Inserta este dato en un campo Boolan
         Datos.QrySolicitud.SQL.Add(Quotedstr(lblUsuarioCreador.caption) + ',');
         Datos.QrySolicitud.SQL.Add(Quotedstr(lblDireccion.caption) + ')');
         Datos.QrySolicitud.ExecSQL;
end;


gracias por su ayuda
Responder Con Cita
  #2  
Antiguo 17-02-2009
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
¿Y cuál es el problema?

// Saludos
Responder Con Cita
  #3  
Antiguo 17-02-2009
tebre tebre is offline
Miembro
 
Registrado: nov 2008
Posts: 93
Poder: 16
tebre Va por buen camino
error

me marca un error que dice algo asi:


[Error] USolicitud.pas(227): E2010 Incompatible types: 'string' and 'Boolean'

pero mi compo en mi base de datos es boolean
Responder Con Cita
  #4  
Antiguo 17-02-2009
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Quítale eso de QuotedStr al campo booleano y usa algo como BoolToStr:

Código Delphi [-]
Datos.QrySolicitud.SQL.Add(BoolToStr(Boleano, true) + ',')

// Saludos
Responder Con Cita
  #5  
Antiguo 17-02-2009
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
tus datos son booleanos, pero la propiedad SQL de tu dataset es String... tendrías que usar la función BoolToStr para cambiar tus booleanos a cadena...

o mejor aún, podrías utilizar parámetros y no tendrías que hacer ninguna conversión de tipos de datos...





changos, me tarde... todo por bostezar antes de enviar la respuesta...jaja
__________________

Responder Con Cita
  #6  
Antiguo 17-02-2009
tebre tebre is offline
Miembro
 
Registrado: nov 2008
Posts: 93
Poder: 16
tebre Va por buen camino
Ok

Bueno ya esta ahora ya me ingreso los datos............lo que veo es que me guarda en formato asi "01/01/1900 00:00:00" en la base de datos..ahora se supone que la otra parte es la hora porque no me almaceno la hora correcta??

como hacerle...para que me agregue la hora correcta...


espero su respuesta gracias........
Responder Con Cita
  #7  
Antiguo 18-02-2009
Avatar de ElKurgan
[ElKurgan] ElKurgan is offline
Miembro Premium
 
Registrado: nov 2005
Posts: 1.235
Poder: 20
ElKurgan Va camino a la fama
Cita:
Empezado por tebre Ver Mensaje
Datos.QrySolicitud.SQL.Add(dateToStr(DtpFechaCreacion.Date) + ','); //insertar dato tipo fecha
Date te devuelve la fecha en formato TDateTime pero
con el valor Time a cero. Prueba mejor con "Now"

Un saludo
Responder Con Cita
  #8  
Antiguo 18-02-2009
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
Utilizando parámetros no tendrías que hacer ninguna conversión, ni booltostr, ni datetostr.
__________________

Responder Con Cita
  #9  
Antiguo 18-02-2009
tebre tebre is offline
Miembro
 
Registrado: nov 2008
Posts: 93
Poder: 16
tebre Va por buen camino
mensaje

hola contraveneno..veo que me insiste en eso de envio de parametros pero apenas empiezo en delphi y todo es nuevo para mi..si me pudiera dar un ejemplo..y decirme donde radica la diferencia te lo agradeceria...

gracias a todos los del foro..muy bueno!!
Responder Con Cita
  #10  
Antiguo 18-02-2009
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
Tu estas utilizando esta forma:
Código Delphi [-]
With UnADOQuery do begin
 If active then close;
 SQL.Clear;
 SQL.Add('Insert Into Tabla(UnCampo, OtroCampoFecha, CampoBoolean)');
 SQL.Add('Values('+QuotedStr(UnEdit.Text)+', '+DateToStr(UnaFecha.Date)+', '+BoolToStr(UnCheckBox.Checked)+')');
 ExecSQL;
end; //with

Lo que estas haciendo ahí, es cambiar el valor de la fecha a un valor de tipo cadena (String) con el formato que tengas establecido. Lo mismo se aplica para cualquier otro tipo de datos, ya sea boolean, float, currency, integer, etc. Todo lo tendrías que convertir a cadena.

El problema con cambiar todo a cadena de texto, es que tendrías que lidiar con los formatos. Por ejemplo, para las fechas, tendrías que definir si va a ser con formato yyyymmdd, o yyyy/dd/mm o dd/mm/yyyy. Para los tipos moneda, tendrías que ver si el formato esta definiendo los puntos como separador de miles, o si son las comas los separadores de miles, si es con signo o sin signo. En fin, en pocas palabras, tendrías que cuidar por medio de programación, el formato adecuado para cada tipo de dato. Y cada base de datos utiliza un formato distinto.

Si utilizas parámetros, no tienes que preocuparte por eso y no tendrías que validar formatos, ni cambiar formatos, ni codificar nada para esto. Aquí un ejemplo:
Código Delphi [-]
With UnADOQuery do begin
 If active then close;
 SQL.Clear;
 SQL.Add('Insert Into Tabla(UnCampo, OtroCampoFecha, CampoBoolean)');
 SQL.Add('Values(:UnCampo, :UnaFecha, :UnBoolean)');
 Parameters.ParamByName('UnCampo').Value := UnEdit.Text;
 Parameters.ParamByName('UnaFecha').Value := UnaFecha.Date;
 Parameters.ParamByName('UnBoolean').Value := unCheckBox.Checked;
 ExecSQL;
end; //with

En este pequeño ejemplo, si te fijas, no estoy haciendo ninguna conversión con la fecha y sistema seleccionará automáticamente el formato adecuando para guardarlo en la base de datos. Y lo mismo aplica para todos los tipos de datos, el sistema elegirá el formato correcto.

Ejemplo utilizando BDE en lugar de ADO:
Código Delphi [-]
 With UnBDEQuery do begin
  If active then close;
  SQL.Clear;
  SQL.Add('Insert Into Tabla(UnCampo, OtroCampoFecha, UnCampoBoolean)');
  SQL.Add('Values(:UnCampo, :UnaFecha, :UnBoolean)');
  ParamByName('UnCampo').AsString := UnEdit.Text;
  ParamByName('UnaFecha').AsDateTime := UnaFecha.Date;
  ParamByName('UnBoolean').AsBoolean := unCheckBox.Checked;
  ExecSQL;
 end; //with

Espero haberme explicado correctamente y haber dejado claro cuál es la ventaja de utilizar parámetros.
Saludos.
__________________


Última edición por ContraVeneno fecha: 18-02-2009 a las 19:34:23.
Responder Con Cita
  #11  
Antiguo 18-02-2009
tebre tebre is offline
Miembro
 
Registrado: nov 2008
Posts: 93
Poder: 16
tebre Va por buen camino
parametros

ahora mismo lo intentare y te cuento gracias
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
error al Insertar sidneyb SQL 3 10-03-2008 18:22:29
Error al Insertar con ADO trex2000 Conexión con bases de datos 1 18-01-2007 11:16:52
error al insertar beatriz g SQL 3 24-08-2006 10:29:33
Error al insertar un registro en la BD RiverPlate Conexión con bases de datos 3 08-12-2004 15:53:18
Error al insertar utilzando ADO Luis Castillo Conexión con bases de datos 1 19-06-2003 10:21:36


La franja horaria es GMT +2. Ahora son las 07:41:48.


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