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 :

Test Existence d'une base de données


Sujet :

C#

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2011
    Messages : 125
    Points : 72
    Points
    72
    Par défaut Test Existence d'une base de données
    Bonjour, je voudrais faire un test avec le code c# pour voir si une base de données sql server existe ou pas.

    j'ai pensé à utiliser cette requête pour faire le test

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM sys.database_principals WHERE name = N'BD'

    mais comment récupérer le résultat

  2. #2
    Membre expérimenté Avatar de callo
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Février 2004
    Messages
    887
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Togo

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 887
    Points : 1 699
    Points
    1 699
    Par défaut
    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
    private void IsDataBaseExist(string nomBaseDonnees)
    {
        string sqlCheck;
        bool result = false;
     
        try
        {
            SqlConnection connex = new SqlConnection(MyConnectionString);
     
            string sqlCheck = string.Format("SELECT database_id FROM sys.databases WHERE Name = '{0}'", nomBaseDonnees);
     
            using (connex)
            {
                using (SqlCommand sqlCmd = new SqlCommand(sqlCheck, connex))
                {
                    connex.Open();
                    int databaseID = (int)sqlCmd.ExecuteScalar();    
                    connex.Close();
     
                    result = (databaseID > 0);
                }
            }
        } 
        catch (Exception ex)
        { 
            result = false;
        }
     
    	if (result)
    	{
    		MessageBox.Show("La base de données existe");
    	}
    	else
    	{
    		MessageBox.Show("La base de données n'existe pas");
    	} 
    }
    N'oubliez pas le tag et

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2011
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2011
    Messages : 14
    Points : 24
    Points
    24
    Par défaut
    Bonjour tu peux aussi utiliser les objets smo, ils te permettront de découvrir les différent serveurs accessibles et toutes leurs bases de données.

    ci joint une petite implémentation de base

    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
     
    using System;
    using System.Collections.Generic;
    using Microsoft.SqlServer.Management.Common;
    using Microsoft.SqlServer.Management.Smo;
     
    namespace Test
    {
        class Program
        {
            static void Main(string[] args)
            {
                ServerConnection serverConnection = new ServerConnection("Le nom du serveur que je veux");
     
                bool isExistDB = false; 
                Server server = new Server(serverConnection);
                string dbNameToFind = "Le nom de la DB que je cherche";
                List<string> databasesInServerList = new List<string>();
     
                foreach (Database db in server.Databases)
                    if (!db.IsSystemObject)
                        databasesInServerList.Add(db.Name);
     
                if(databasesInServerList.Contains(dbNameToFind))
                    isExistDB = true;
     
                Console.WriteLine(isExistDB.ToString());
                Console.ReadLine();
            }   
        }
    }
    Les dll à ajouter en ref sont Microsoft.SqlServer.ConnectionInfo, Microsoft.SqlServer.Management.Sdk.Sfc, Microsoft.SqlServer.Smo

    En adaptant un peu le code en fonction de la sécu serveur tu peux te connecter sur tous tes serveurs et checker si tu trouves ta DB

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2005
    Messages
    482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2005
    Messages : 482
    Points : 625
    Points
    625
    Par défaut
    salut,
    j'aurais été plus général;
    visiblement tu ne connais pas ADO.NET et te donner du code tout fait ne t'aidera pas à progresser :p
    donc cherche un cours sur ADO.NET
    "Essayer est le premier pas vers l'Echec !" (Homer Simpson)

Discussions similaires

  1. L'existence d'une base de donnée
    Par ayoubkira dans le forum JDBC
    Réponses: 5
    Dernier message: 11/08/2010, 17h20
  2. Réponses: 3
    Dernier message: 21/01/2009, 18h14
  3. Existence d'une base de donnée
    Par Emilie012 dans le forum Requêtes
    Réponses: 2
    Dernier message: 04/09/2008, 13h14
  4. [MySQL] Tester l'existence d'une base de données
    Par loukili81 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 16/05/2006, 10h40
  5. Réponses: 1
    Dernier message: 23/10/2005, 00h55

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