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

Administration SQL Server Discussion :

Une Question Bête


Sujet :

Administration SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2008
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 101
    Par défaut Une Question Bête
    Bonjour ,

    J'ai une question bête :

    J'ai désactivé les contraintes sur une BDD afin de pouvoir temporairement insérer des données en masse.
    Je n'arrive plus à réactiver ces contraintes.

    Voilà la question bête, est ce qu' en restaurant cette BDD à une date antérieure , je peux retrouver mes contraintes activées?


    Voici le script que j'ai utilisé pour désactiver et réactiver les contraintes de ma BDD .

    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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
     
     
    -- Script de désactivation des contraintes FK d'une base de données
    -- Déclaration de la variable qui va contenir les requetes à exécuter
    Declare @Requete VarChar(1000)
    -- Déclaration du curseur qui va contenir pour chaque FK, une requete de désactivation
    Declare Cur_Contrainte Cursor For
    	select 'ALTER TABLE ' + t.name + ' NOCHECK CONSTRAINT ' + fk.name 
    	from sysobjects fk, sysobjects t
    	where fk.type='F' and fk.parent_obj=t.id
    	order by t.name
    Open Cur_Contrainte
    -- Boucle sur le curseur et exécution des requetes
    Print 'Désactivation des contraintes en cours, Patience ....'
    Fetch Next From Cur_Contrainte Into @Requete
    While @@Fetch_Status = 0
    Begin
    	-- Possibiliter d'afficher les requetes exécutées en supprimant le commentaire ci dessous
    	-- Print @Requete
    	Execute (@Requete)
    	Fetch Next From Cur_Contrainte Into @Requete
    End
    -- Fermeture du curseur et libération des ressources
    Close Cur_Contrainte
    Deallocate Cur_Contrainte
    Print 'Désactivation des contraintes terminée !'
     
     
    -- Script de réactivation des contraintes FK d'une base de données
    -- Déclaration de la variable qui va contenir les requetes à exécuter
    Declare @Requete VarChar(1000)
    -- Déclaration du curseur qui va contenir pour chaque FK, une requete de réactivation
    -- Précision : l'option WITH CHECK CHECK permet de forcer le moteur à activer la contrainte 
    --	       mais aussi à vérifier que le contenu des tables est conforme aux contraintes
    --	       sinon il est possible de ne mettre que l'option "CHECK" mais dans ce cas, la contrainte
    --	       est activée sans controle de l'existant
    Declare Cur_Contrainte Cursor For
    	select 'ALTER TABLE ' + t.name + ' WITH CHECK CHECK CONSTRAINT ' + fk.name 
    	from sysobjects fk, sysobjects t
    	where fk.type='F' and fk.parent_obj=t.id
    	order by t.name
    Open Cur_Contrainte
    -- Boucle sur le curseur et exécution des requetes
    Print 'Réactivation des contraintes en cours, Patience ....'
    Fetch Next From Cur_Contrainte Into @Requete
    While @@Fetch_Status = 0
    Begin
    	-- Possibiliter d'afficher les requetes exécutées en supprimant le commentaire ci dessous
    	-- Print @Requete
    	Execute (@Requete)
    	Fetch Next From Cur_Contrainte Into @Requete
    End
    -- Fermeture du curseur et libération des ressources
    Close Cur_Contrainte
    Deallocate Cur_Contrainte
    Print 'Réactivation des contraintes terminée !'
    Merci d'avance

  2. #2
    Membre Expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Par défaut
    Il faudrait stocker la requête de réactivation avant de désactiver les contraintes...

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2008
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 101
    Par défaut
    Donc plus moyen de récupérer mes contraintes, si j'ai exécuté mon script de désactivation avant celui de réactivation?


  4. #4
    Membre Expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Par défaut
    C'est çà :-) tu les as supprimées donc quand tu interroges les tables sysobjects il ne te renvois rien puisqu'elles n'existe plus...

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Décembre 2008
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 101
    Par défaut
    Merci pour l'info !

    et avec une restauration de BDD ça ne reviens pas ?

  6. #6
    Membre Expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Par défaut
    Si

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 25/09/2010, 14h38
  2. Une question bête sur la mise en forme
    Par couistelle dans le forum Débuter
    Réponses: 3
    Dernier message: 26/11/2008, 15h08
  3. une question bête : type de projet VB6 pro
    Par hpfx dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 23/02/2008, 18h43
  4. Une question surement bête
    Par PLoUf88 dans le forum Langage
    Réponses: 3
    Dernier message: 28/05/2007, 12h01
  5. Réponses: 2
    Dernier message: 04/10/2006, 14h03

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