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éfinir la valeur de l'auto increment sur une base Access


Sujet :

Bases de données Delphi

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2007
    Messages : 15
    Points : 20
    Points
    20
    Par défaut Définir la valeur de l'auto increment sur une base Access
    Bonjour,

    Je cherche à savoir comment faire pour définir (forcer) la valeur de l'auto incrément d'un champ (clé primaire) dans une table en Delphi5.

    J'utilise ce bout de code utilisant Jet Engine trouvé sur delphi.about.com pour compacter la base de données access :

    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
    23
    24
    25
    26
    27
    28
    29
    30
    function CompactDatabase (const sdbName: string) : boolean;
    var
     JE          : TJetEngine; //Jet Engine
     sdbTemp     : string;     //TEMP database
     sdbTempConn : string;     //Connection string
    const
     SProvider = 'Provider=Microsoft.Jet.OLEDB.4.0; Data Source=';
    begin
     Result := False;
     sdbTemp := ChangeFileExt(sdbName, '.tmp');
     sdbTempConn := SProvider + sdbtemp;
     
     if FileExists(sdbTemp) then
        DeleteFile(PChar(sdbTemp));
     
     JE := TJetEngine.Create(nil);
     try
      try
        JE.CompactDatabase(SProvider + sdbName, sdbTempConn);
        DeleteFile(PChar(sdbName));
        RenameFile(sdbTemp, sdbName);
        Result := True;
      except
        on E:Exception do
               ShowMessage(E.Message);
      end;
     finally
       JE.FreeOnRelease;
     end;
    end;
    En appelant cette fonction, je réinitialise la valeur de l'auto incrément à 1 de plus que la valeur du plus grand index. Donc si auparavant j'ai vidé la table avec un DELETE FROM MaTable je remet l'auto incrément de la clé à 1.


    Maintenant j'aimerai pouvoir fixer cette valeur d'auto incrément (sur une table vide) à une valeur arbitraire (par exemple 20000). Comment pourrais-je procéder, sachant qu'avec une connexion de type ADOQuery je ne peux utiliser que des requêtes du type INSERT, UPDATE ou DELETE. Donc pas de ALTER ou autre comme en MySQL par exemple.


    Merci d'avance pour toute proposition,

    CardinalJo

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Octobre 2007
    Messages : 15
    Points : 20
    Points
    20
    Par défaut Insertions bidons
    Une idée (de loin pas la plus classieuse) serait, une fois la table vidée et compactée, d'ajouter à l'aide de commandes INSERT 20000 - 1 enregistrements bidons (afin de faire grandir l'auto increment) puis de les supprimer sans recompacter la base, laissant ainsi l'auto increment à la valeur désirée.

    Je pense utiliser cette solution temporairement en attendant une éventuelle meilleure proposition ;-)

  3. #3
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 586
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 586
    Points : 25 254
    Points
    25 254
    Par défaut
    Dans le cas du DELETE FROM, remplace cela par une séquence
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    DROP TABLE sdbName
    CREATE TABLE sdbName
    (
    Id PRIMARY KEY AUTOINCREMENT(2000,1),
    ...

    Si la table n'est pas vide, tenter un ALTER DROP COLUMN ID et de la recréer si ACCESS supporte ce genre de manip


    En MySQL MyIsam, c'est très simple
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    ALTER TABLE sdbName AUTO_INCREMENT = 2000

  4. #4
    Membre chevronné Avatar de philnext
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 552
    Points : 1 780
    Points
    1 780
    Par défaut
    Pourquoi ne peux tu pas utiliser de ALTER ?

Discussions similaires

  1. Simuler un comportement en auto increment sur une colonne
    Par abc.xyz dans le forum Administration
    Réponses: 18
    Dernier message: 20/08/2015, 15h14
  2. Auto Increment sur une propriété
    Par ElSkud dans le forum Hibernate
    Réponses: 2
    Dernier message: 29/06/2008, 18h14
  3. Pb de connexion sur une base access
    Par xave dans le forum ASP
    Réponses: 9
    Dernier message: 17/01/2006, 17h26
  4. requetes BUSINESS OBJECT sur une base ACCESS
    Par greatmaster1971 dans le forum Deski
    Réponses: 1
    Dernier message: 06/10/2004, 14h10
  5. Pb d'auto-incrément sur une table v7
    Par Nivux dans le forum Paradox
    Réponses: 9
    Dernier message: 26/12/2002, 12h05

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