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

MS SQL Server Discussion :

use database


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Mars 2004
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 24
    Par défaut use database
    Bonjour tout le monde

    J'ai un script qui génére une erreur que je n'arrive pas à comprendre,
    Le voici :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    if exists (select name from master.dbo.sysdatabases where name like 'restauration')
    	begin	
    		use master
    		drop database restauration
    	end
    	create database restauration
    	use restauration
    Voila ce qu'il me dit concernant la ligne 'use restauration' :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Impossible de trouver l'entrée dans sysdatabases pour la base de données  'restauration'. Aucune entrée ne porte ce nom. Assurez-vous que le nom est correctement saisi.
    J'ai cette erreur si au départ la base restauration n'est pas présente sur le serveur.

    En fait j'utilise une base temporaire. A chaque fois que je lance le script, si elle exite je la supprime et ensuite je la crée ou la recrée. Comme ensuite je lui crée des tables je fait une use restauration pour pouvoir travailler dessus.

    je ne comprend pas pourquoi il me dit qu'il ne trouve pas la base puisque je la crée juste avant.

    Quand j'execute le script en deux fois, il n'y a pas de problème. c'est à dire que je commence par supprimer la base si elle existe puis je la recrée.
    Ensuite je fais fais le use séparement et là ça marche.

    On dirait que l'analyseur de requête vérifie si la base existe bien avant d'exécuter le script et comme elle n'y est pas il m'envoie une erreur .
    Mais ça me paraît bizarre

    Merci pour tous conseils
    Nicolas

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 228
    Billets dans le blog
    25
    Par défaut
    Entre le create et le use, il faut avoir un go (= 2 transactions distinctes), sinon le parser essaie de faire le use avant de lancer l'ordre de creation, d'où votre message d'erreur.
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  3. #3
    Membre averti
    Inscrit en
    Mars 2004
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Mars 2004
    Messages : 24
    Par défaut
    Merci Fadace

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

Discussions similaires

  1. NetBeans 7.2: Entreprise Resources => use database
    Par janyoura dans le forum NetBeans
    Réponses: 0
    Dernier message: 30/01/2013, 01h13
  2. Connecting to Database Using Custom Webpart in Sharepoint 2007
    Par informaticienne_2009 dans le forum SharePoint
    Réponses: 7
    Dernier message: 29/07/2009, 17h23
  3. Recover database using backup controlfile
    Par wattman dans le forum Administration
    Réponses: 15
    Dernier message: 19/09/2008, 22h40
  4. utiliser use database
    Par widom dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 21/05/2007, 16h14
  5. tutoriel : Database.Open-Could not use, file already in use
    Par MARTIN Gérard dans le forum XMLRAD
    Réponses: 2
    Dernier message: 04/05/2005, 11h56

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