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

C# Discussion :

fonction d'elimination du vide access


Sujet :

C#

  1. #1
    Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 106
    Points : 56
    Points
    56
    Par défaut fonction d'elimination du vide access
    bonjour
    y a t il une fonction qui permet d'eliminer le vide lors du stockage dans une base de données access via une application c#
    merci

  2. #2
    Responsable .NET

    Avatar de Hinault Romaric
    Homme Profil pro
    Consultant
    Inscrit en
    Janvier 2007
    Messages
    4 570
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Consultant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2007
    Messages : 4 570
    Points : 252 372
    Points
    252 372
    Billets dans le blog
    121
    Par défaut
    Je ne te comprend pas bien mais si tu a par une exemple un string Var de type String tu peut faire Var.Trim(), cette fonction supprime les espace a gauche et a droite de la variable .

    @++
    Vous souhaitez participer aux rubriques .NET ? Contactez-moi

    Si déboguer est l’art de corriger les bugs, alors programmer est l’art d’en faire
    Mon blog, Mes articles, Me suivre sur Twitter
    En posant correctement votre problème, on trouve la moitié de la solution

  3. #3
    Membre habitué
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juin 2007
    Messages
    72
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 72
    Points : 135
    Points
    135
    Par défaut
    En fait, tu cherche a compacter ta bdd en supprimant les lignes marquées effacées mais qui n'ont pas ecnore été zappée. Désolé, mais il me semble que ce genre de fonction n'existe qu'a partir de l'interface d'access lui même.

  4. #4
    Membre éprouvé Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Points : 1 188
    Points
    1 188
    Par défaut
    bonjour,

    et non tu peux faire ça à partir du code en c# directement :
    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
    31
    32
    33
    34
    35
    36
    37
    38
    39
     
    using System;
    using System.IO;
     
    namespace CompactMDB {
      class Class1 {
        [STAThread]
        static void Main(string[] args) {
          // http://support.microsoft.com/kb/306287/
          if (args.Length != 1) {
            Console.WriteLine(@"CompactMDB D:\path\database.mdb");
          } else {
            string dbName = args[0].Trim();
            string dbTemp = string.Concat(dbName, "_pak");
            string provider = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=";
            try {
              JRO.JetEngine jet = new JRO.JetEngine();
              jet.CompactDatabase(provider + dbName, provider + dbTemp);
            } catch (Exception ex) {
              Console.WriteLine(ex.Message);
              dbName = "";
            }
            if (!string.IsNullOrEmpty(dbName )) {
              try {
                FileInfo fi = new FileInfo(dbName);
                string result = dbName + " : " + fi.Length.ToString();
                File.Delete(dbName);
                File.Move(dbTemp, dbName);
                fi.Refresh();
                result += " -> " + fi.Length.ToString();
                Console.WriteLine(result);
              } catch (Exception ex) {
                Console.WriteLine(ex.Message);
              }
            }
          }
        }
      }
    }
    ça devrait bien fonctionner, c'est du code pris directement sur ici et optimisé très vite fait...
    Un âne se croit savant parce qu'on le charge de livres (proverbe américain)

    N'oubliez pas de avant de
    Pas de question techniques par MP, c'est contre la philosophie du forum

  5. #5
    Membre du Club
    Inscrit en
    Juillet 2009
    Messages
    106
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 106
    Points : 56
    Points
    56
    Par défaut re
    j'ai pas compris le fait de compacter la base de donnée!!
    mon pblem est le suivant:
    quand j enregsitre dans une base de données acess ,y a le vide qui s ajoute a coté du string par exemple alors quand je fais la jointure suivant un champs communs qui normalement va donner un joiture parfaite,y a le null du coté du champs avec le blanc,alors j elimine le blanc manuellement et je refait la jointure et ça marche!!mais vu que c est tres fatigant de le faire manuellement surtt avec un base de données pesante!!
    merci

  6. #6
    Membre éprouvé Avatar de sisqo60
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Février 2006
    Messages
    754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 754
    Points : 1 188
    Points
    1 188
    Par défaut
    tu dois utiliser des char(X) et non des varchar(X)... ça doit être tout.
    Sinon je comprends pas du tout ce que tu dis...
    Sois plus explicite.
    Un âne se croit savant parce qu'on le charge de livres (proverbe américain)

    N'oubliez pas de avant de
    Pas de question techniques par MP, c'est contre la philosophie du forum

Discussions similaires

  1. Equivalent de la fonction STXT d'Excel dans Access
    Par gme69 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 14/05/2007, 08h51
  2. eliminer les vides dans une liste
    Par alphonse62 dans le forum Débuter avec Java
    Réponses: 4
    Dernier message: 08/05/2007, 18h13
  3. fonctions EoMonth et Weeknum dans Access
    Par NATOU2 dans le forum Access
    Réponses: 1
    Dernier message: 16/01/2007, 15h33
  4. TTreeView, DragOver le "vide" => access violation
    Par netah25 dans le forum C++Builder
    Réponses: 2
    Dernier message: 21/09/2006, 21h13
  5. Fonction "Envoyer comme message" sous ACCESS 2.0
    Par JACQUEMIN dans le forum Access
    Réponses: 2
    Dernier message: 24/03/2006, 12h43

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