[Lazarus-es] Eliminar registro en BD SQLite

Jose Antonio. Cuello Principal jcuello en artextrading.com
Jue Jun 28 18:26:04 CEST 2012


prueba ese mismo código pero con un starttransaction antes y un commit despues del execsql.

debería funcionar.
Un saludo

----- Mensaje original -----
De: "Maikel Enrique Pernía Matos" <reprepoli2mz en infomed.sld.cu>
Para: "Spanish version of Lazarus List" <lazarus-es en lists.lazarus.freepascal.org>
Enviados: Miércoles, 27 de Junio 2012 17:18:00
Asunto: Re: [Lazarus-es] Eliminar registro en BD SQLite

Jose Antonio, ya hice eso pero aún cuando hago una eliminación de un  
registro los cambios no son permanentes, después de cerrar la app y  
volverla a abrir allí está el registro eliminado, verifiqué los  
permisos que tiene el fichero de la BD y todo esta bien. Por último  
hice una rutina para eliminar los registros y el comportamiento es el  
mismo anexo el código.

<code>
//procedimeinto para eliminar registro.
procedure TForm1.EliminaRegistro(reg : String);
begin
    with SQLQuery1 do begin
       Close;
       SQL.Clear;
       SQL.Add('DELETE FROM persona WHERE id = ' + reg);
       ExecSQL;
       Close;
    end;
end;
</code>

El mar, 26-06-2012 a las 05:50 +0000, Jose Antonio. Cuello Principal escribió:
Para usar los dbcontrols tienes que enlazarlos, junto con el  
componente dataset (en tu caso el TSqlite3Dataset), mediante un  
datasource (componente que está en la pestaña "Data Access").
>
> Tanto los componentes como el dataset tienen una propiedad  
> "Datasource" donde asignar el datasource que has añadido y por el  
> cual se enlanzan.
>
> Un saludo
>
> ----- Mensaje original -----
> De: "Maikel Enrique Pernía Matos" <reprepoli2mz en infomed.sld.cu>
> Para: "Spanish version of Lazarus List"  
> <lazarus-es en lists.lazarus.freepascal.org>
> Enviados: Lunes, 25 de Junio 2012 21:16:42
> Asunto: Re: [Lazarus-es] Eliminar registro en BD SQLite
>
> Error el mio, no especifique en el mail anterior que intento  
> utilizar  el TDBNavigator, para las tareas propias de edición  
> (insertar,  eliminar, editar y actualizar o refrescar la Tabla), es  
> por eso que no  incluí una sintaxis de eliminación en SQL que estoy  
> casi seguro  funcionaría en el trozo de código envié a la lista.
> ahora instalé un paquete que viene con lazarus que agrega el   
> componente "TSqlite3Dataset"; pero en lo poco que he probado no  
> puedo  asignarlo en la propiedad "DataSource" de cualquier  
> componente de los  "DbCtrls"
>
> Saludos
>
> El lun, 25-06-2012 a las 11:01 -0400, Jorge M. Martinez Saez escribió:
> El 25-06-2012 9:44, Maikel Enrique Pernía Matos escribió:
> > > Hola, estoy desarrollando desde Lazarus, una app que utiliza  >  
> SQLite > como BD, hasta ahora puedo conectarme con la base de datos   
> > e insertar > datos en la tabla de forma permanente; pero el  
> problema  > está en la > posibilidad de eliminar un registro de la  
> tabla.
> > >
> > > Agrego el código de conexión y manejo de la Base de Datos:
> > > <code>
> > >  Un formulario con los siguientes componentes:
> > >   Button1: TButton;
> > >   Datasource1: TDatasource;
> > >   DBEdit1: TDBEdit;
> > >   DBGrid1: TDBGrid;
> > >   DBNavigator1: TDBNavigator;
> > >   SQLite3Connection1: TSQLite3Connection;
> > >   SQLQuery1: TSQLQuery;
> > >   SQLTransaction1: TSQLTransaction;
> > >
> > >
> > >  //Procedimiento para configurar los componentes y activar la conexión:
> > >  procedure TForm1.Button1Click(Sender: TObject);
> > >  begin
> > >    with SQLite3Connection1 do begin
> > >       DatabaseName := '/home/maikel/prueba.alf';
> > >       LoginPrompt  := False;
> > >       Transaction  := SQLTransaction1;
> > >       Connected    := True;
> > >    end;
> > >
> > >    with SQLQuery1 do begin
> > >       SQL.Add('SELECT nombre FROM persona');
> > >       Transaction := SQLTransaction1;
> > >       DataBase    := SQLite3Connection1;
> > >       Active      := True;
> > >    end;
> > >
> > >    SQLTransaction1.Active  := True;
> > >    Datasource1.DataSet     := SQLQuery1;
> > >    DBGrid1.DataSource      := Datasource1;
> > >    DBNavigator1.DataSource := Datasource1;
> > >    DBEdit1.DataSource      := Datasource1;
> > >    DBEdit1.DataField       := 'nombre';
> > >  end;
> > >
> > >  //Procedimeinto para almacenar permanentemente los datos
> > >  //luego de la inserción.
> > >  procedure TdmDatos.SQLQuery1AfterPost(DataSet: TDataSet);
> > >  begin
> > >     SQLQuery1.ApplyUpdates();
> > >     SQLQuery1.CommitRetaining;
> > > end;
> > > </code>
> > >
> > >
> > >
> > > ----------------------------------------------------------------
> > > This message was sent using IMP, the Internet Messaging Program.
> > >
> > >
> > > -- >
> > > Este mensaje le ha llegado mediante el servicio de correo  >  
> electronico > que ofrece Infomed para respaldar el cumplimiento de   
> > las misiones del > Sistema Nacional de Salud. La persona que envia  
>  > este correo asume el > compromiso de usar el servicio a tales  
> fines  > y cumplir con las > regulaciones establecidas
> > >
> > > Infomed: http://www.sld.cu/
> > >
> > > _______________________________________________
> > > Lazarus-es mailing list
> > > Lazarus-es en lists.lazarus.freepascal.org
> > > http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus-es
> > >
> > Hola Maikel:
> >
> > Cual es el codigo que usas para eliminar los datos?
> >
> > Has revisado los permisos que el usuario tiene sobre la base?  
> (para eliminar)
> >
> > Atte
> >
> > -- Jorge Martinez Saez 9-8817012
> >
> > _______________________________________________
> > Lazarus-es mailing list
> > Lazarus-es en lists.lazarus.freepascal.org
> > http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus-es
> >
>
> ----------------------------------------------------------------
> This message was sent using IMP, the Internet Messaging Program.
>
>
> --
>
> Este mensaje le ha llegado mediante el servicio de correo  
> electronico que ofrece Infomed para respaldar el cumplimiento de las  
> misiones del Sistema Nacional de Salud. La persona que envia este  
> correo asume el compromiso de usar el servicio a tales fines y  
> cumplir con las regulaciones establecidas
>
> Infomed: http://www.sld.cu/
>
> _______________________________________________
> Lazarus-es mailing list
> Lazarus-es en lists.lazarus.freepascal.org
> http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus-es
>
> _______________________________________________
> Lazarus-es mailing list
> Lazarus-es en lists.lazarus.freepascal.org
> http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus-es
>

----------------------------------------------------------------
This message was sent using IMP, the Internet Messaging Program.


--

Este mensaje le ha llegado mediante el servicio de correo electronico que ofrece Infomed para respaldar el cumplimiento de las misiones del Sistema Nacional de Salud. La persona que envia este correo asume el compromiso de usar el servicio a tales fines y cumplir con las regulaciones establecidas

Infomed: http://www.sld.cu/

_______________________________________________
Lazarus-es mailing list
Lazarus-es en lists.lazarus.freepascal.org
http://lists.lazarus.freepascal.org/mailman/listinfo/lazarus-es




More information about the Lazarus-es mailing list