IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bases de données Delphi Discussion :

Débuts avec SQLite et Zeos ; comment créer une table ?


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Août 2007
    Messages
    159
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 159
    Par défaut Débuts avec SQLite et Zeos ; comment créer une table ?
    on ma conseillé le Sqlite mais j’ai du mal a trouver des tutoriel pour expliqué comment l'utilisé avec delphi 7

  2. #2
    Modérateur
    Avatar de tourlourou
    Homme Profil pro
    Biologiste ; Progr(amateur)
    Inscrit en
    Mars 2005
    Messages
    3 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Biologiste ; Progr(amateur)

    Informations forums :
    Inscription : Mars 2005
    Messages : 3 938
    Billets dans le blog
    6
    Par défaut
    Regarde la Zeos Lib, peut-être
    Delphi 5 Pro - Delphi 11.3 Alexandria Community Edition - CodeTyphon 6.90 sous Windows 10 ; CT 6.40 sous Ubuntu 18.04 (VM)
    . Ignorer la FAQ Delphi et les Cours et Tutoriels Delphi nuit gravement à notre code !

  3. #3
    Membre confirmé
    Inscrit en
    Août 2007
    Messages
    159
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 159
    Par défaut
    je rame toujours avec le Sqlite y a pas un tuto ou un exemple comment l’utilisé avec le delphi 7 juste les info de base
    - installé le Sqlite avec delphi
    - crée une base sqlite
    - l'ajout
    - suppression
    - modification
    - recherche
    ??

  4. #4
    Membre Expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 573
    Par défaut
    Salut

    Plutôt que SQLLite, utilise Firebird, autant faire les choses en grand. Même pour une application monoposte, ça reste pertinent grâce à la version Embedded du serveur pour laquelle serveur et client sont ensemble en local.

    ZeosLIB fonctionne bien avec FB.

    SQLLite a l'avantage d'être "léger" (pléonasme) car le moteur est embarqué dans l'exécutable mais je ne l'ai jamais mis en oeuvre.

    Avec des BLOB Texte tu pourras charger un fichier texte dans un seul champ, petit veinard.

    Paradox a le défaut d'être un peu gourmand en ressource (nombre de fichiers à ouvrir simultanément, d'être obsolète (et encore cela se discute) et surtout de ne pas se comporter toujours très bien en réseau surtout s'il y a de nombreux utilisateurs.

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  5. #5
    Membre confirmé
    Inscrit en
    Août 2007
    Messages
    159
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 159
    Par défaut
    j'ai enfin pu réaliser le traitement avec les composant Zeolib +Sqlite3

    pour l'ajout nouveau enregistrement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    procedure TForm1.Button3Click(Sender: TObject);
    begin
      // Si aucun enregistrement
      if DbGrid1.Datasource.Dataset.RecordCount = 0 then
        Exit;
      // Si aucun sélectionné
      if DbGrid1.Datasource.Dataset.RecNo < 0 then
        Exit;
      // ajouter un nouveau enrejestrement
      begin
        // Passer en mode édition
        DBGrid1.Datasource.Dataset.Append;
        // ajouter les données
        DBGrid1.Datasource.Dataset.FieldByName('Name').AsString := form1.Edit3.Text;
        DBGrid1.Datasource.Dataset.FieldByName('ProviderID').AsString := form1.Edit4.Text;
        DBGrid1.Datasource.Dataset.FieldByName('KeyIndex').AsString := form1.Edit5.Text;
        DBGrid1.Datasource.Dataset.FieldByName('Key').AsString := form1.Edit6.Text;
        DBGrid1.Datasource.Dataset.FieldByName('Comments').AsString := DateTimeToStr(now);
        // Valider
        DBGrid1.Datasource.Dataset.Post;
     end;
    end;
    Maitre ajour ou Modification
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    procedure TForm1.Button2Click(Sender: TObject);
    begin
      // Si aucun enregistrement
      if DbGrid1.Datasource.Dataset.RecordCount = 0 then
        Exit;
      // Si aucun sélectionné
      if DbGrid1.Datasource.Dataset.RecNo < 0 then
        Exit;
      // Mettre à jour
      begin
        // Passer en mode édition
        DBGrid1.Datasource.Dataset.Edit;
        // Modifier les données
        DBGrid1.Datasource.Dataset.FieldByName('Name').AsString := form1.Edit3.Text;
        DBGrid1.Datasource.Dataset.FieldByName('ProviderID').AsString := form1.Edit4.Text;
        DBGrid1.Datasource.Dataset.FieldByName('KeyIndex').AsString := form1.Edit5.Text;
        DBGrid1.Datasource.Dataset.FieldByName('Key').AsString := form1.Edit6.Text;
        DBGrid1.Datasource.Dataset.FieldByName('Comments').AsString := DateTimeToStr(now);
        // Valider la modification
        DBGrid1.Datasource.Dataset.Post;
     end;
    end;
    Suppression
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    procedure TForm1.Button1Click(Sender: TObject);
    begin
      // Si aucun enregistrement
      if DbGrid1.Datasource.Dataset.RecordCount = 0 then
        Exit;
      // Si il y a un enregistrement courant
      if DbGrid1.Datasource.Dataset.RecNo >= 0 then
        if MessageDlg('Voulez vous vraiment supprimer cet enregistrement ?',
                           MtConfirmation, MbOkCancel, 0) = mrOk then
          DbGrid1.Datasource.DataSet.Delete;
    end;
    Recherche
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    procedure TForm1.Edit2Change(Sender: TObject);
    begin
      // Arrête le filtrage de la table
      form1.ZTable1.Filtered:=false;
      // Test si il n'y a rien dans le TEdit
      if Trim(Edit1.Text) <> '' then
      begin
        // Construction du Filtre avec le texte saisi dans la zone TEdit
        form1.ZTable1.Filter := 'ProviderID like ' + QuotedStr(Edit2.Text + '*');
        // Activation du filtre
        form1.ZTable1.Filtered := true;
      end;
    end;
    le problème qu il me reste que j'arrive pas a résoudre c'est la création de la base si elle n'existe pas ?
    comment on crée une base Sqlite3 ?

  6. #6
    Modérateur
    Avatar de tourlourou
    Homme Profil pro
    Biologiste ; Progr(amateur)
    Inscrit en
    Mars 2005
    Messages
    3 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Biologiste ; Progr(amateur)

    Informations forums :
    Inscription : Mars 2005
    Messages : 3 938
    Billets dans le blog
    6
    Par défaut
    SQLite crée la base (le fichier) quand on s'y connecte s'il n'existait pas. Je suppose que le TZConnection.Connect devrait le faire.
    Delphi 5 Pro - Delphi 11.3 Alexandria Community Edition - CodeTyphon 6.90 sous Windows 10 ; CT 6.40 sous Ubuntu 18.04 (VM)
    . Ignorer la FAQ Delphi et les Cours et Tutoriels Delphi nuit gravement à notre code !

  7. #7
    Membre confirmé
    Inscrit en
    Août 2007
    Messages
    159
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 159
    Par défaut
    Citation Envoyé par tourlourou Voir le message
    SQLite crée la base (le fichier) quand on s'y connecte s'il n'existait pas. Je suppose que le TZConnection.Connect devrait le faire.
    oui il le fait mais il ne crée pas les champs que je veut

  8. #8
    Modérateur
    Avatar de tourlourou
    Homme Profil pro
    Biologiste ; Progr(amateur)
    Inscrit en
    Mars 2005
    Messages
    3 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Biologiste ; Progr(amateur)

    Informations forums :
    Inscription : Mars 2005
    Messages : 3 938
    Billets dans le blog
    6
    Par défaut
    Il suffit d'un ExecuteDirect( 'CREATE TABLE IF NOT EXISTS matable (id INTEGER...)' );
    Delphi 5 Pro - Delphi 11.3 Alexandria Community Edition - CodeTyphon 6.90 sous Windows 10 ; CT 6.40 sous Ubuntu 18.04 (VM)
    . Ignorer la FAQ Delphi et les Cours et Tutoriels Delphi nuit gravement à notre code !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. comment créer une table avec une clé etrangère?
    Par nassimanocus dans le forum Bases de données
    Réponses: 10
    Dernier message: 13/12/2012, 10h19
  2. comment créer une table avec un nom variable ( le mois actuel)
    Par sarah_insat dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 18/02/2011, 18h00
  3. Comment créer une table avec clé primaire
    Par tavarlindar dans le forum Débuter
    Réponses: 6
    Dernier message: 25/08/2010, 13h04
  4. [D6] Comment créer une table Access en SQL avec ADO ?
    Par Lung dans le forum Bases de données
    Réponses: 7
    Dernier message: 18/09/2007, 15h27
  5. Comment créer une Table dans 1 Bdd ACCESS avec Builder??
    Par makandja dans le forum C++Builder
    Réponses: 6
    Dernier message: 17/03/2004, 20h21

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo