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 :

Créer une table au nom aléatoire


Sujet :

MS SQL Server

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 21
    Points : 11
    Points
    11
    Par défaut Créer une table au nom aléatoire
    Bonjour,

    Je dois développer un package DTS d'import. Une des étape de mon import consiste a faire un travail sur les données que l'utilisateur importe. Pour ce faire je veux créer une table temporaire pour y stocker les données à traiter.

    Le problème est que plusieurs utilisateurs peuvent utiliser ce package en même temps. Il est donc important que la table temporaire soit propre à l'utilisateur qui lance le package pour ne pas qu'il y ait de conflit.

    Je ne sait pas trop comment résoudre ce problème.
    J'avais dans l'idée de créer une variable globale contenant 'TEMP_TBL_'+@nom_de_l'utilisateur puis d'utiliser cette variable globale pour créer ma table puis la dropper après utilisation. Mais je n'arrive pas à faire fonctionner cette idée.

    Si quelqu'un à une idée pour me débloquer je suis preneur !!!

    Merci d'avance !

  2. #2
    Membre éprouvé
    Avatar de HULK
    Inscrit en
    Juillet 2003
    Messages
    1 276
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 276
    Points : 1 281
    Points
    1 281
    Par défaut
    quand tu crée une table temporaire, pour ne pas que different utilisateur se marche sur les pieds il suffit de mettre un '#' devant le nom de ta table, en plus quand tu quitte la procedure stockée pas besoin de faire un drop de ta table, ca se fait tout seul, ex :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    CREATE TABLE #tempo ...
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT toto, tata INTO #tempo FROM Table

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 21
    Points : 11
    Points
    11
    Par défaut
    Merci Hulk pour la rapidité de ta réponse

    En fait je ne pense pas pouvoir utiliser de procédures stockées car j'ai en entrée de mon import un fichier plat (.txt) que je dois retraiter avant de l'intégrer dans la base.

    Je m'explique.

    J'utilise donc une tache DTS "Transform Data Task" pour importer les données de mon fichier plats dans la table temporaire.

    Seulement il est possible que plusieurs fichiers plats soient importés en même temps. Je souhaite donc les importer dans une table propre à l'execution du package, retraiter les données sur cette tables pour enfin transférer les données retraitées dans la base de destination.

    Je ne vois pas comment importer les données directement dans une table temporaire.
    De plus une table temporaire qui est crée dans une procédure stocké, est suprimée à la sortie de la procédure. Est-ce possible de créer une table temporaire dans un package DTS qui sera suprimée à la sortie du package ?

  4. #4
    Membre éprouvé
    Avatar de HULK
    Inscrit en
    Juillet 2003
    Messages
    1 276
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 276
    Points : 1 281
    Points
    1 281
    Par défaut
    là je sias pas, je sais que tu peux mettre des taches SQL dans un DTS (le cylindre jaune avec deux fleches rouges).

    Mets en un et essaye de mettre ta requete avec le #

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 21
    Points : 11
    Points
    11
    Par défaut
    Je viens d'essayer en appelant une procédure stockée dans le DTS... Je voulais essayer d'eviter d'utiliser une procédure stocké car ça oblige à déployer non seulement le DTS mais aussi la proc stock...

    Bref ça fonctionne, je fait un bulk insert dans la procédure en utilisant une table #.

    Par contre je me retrouve confronté à un autre problème. Mais comme il n'a rien a voir avec celui-ci je vais regarder si on en parle dans le forum, sinon j'ouvre un autre post.

    Merci pour tes réponses qui m'ont bien aidé

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

Discussions similaires

  1. créer une table dont le nom sera transmis via un post
    Par nad_ii dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 17/03/2015, 10h40
  2. comment créer une table avec un nom variable ( le mois actuel)
    Par sarah_insat dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 18/02/2011, 18h00
  3. Créer une table ayant un nom réservé
    Par azertix dans le forum Requêtes
    Réponses: 4
    Dernier message: 24/12/2009, 13h55
  4. Créer une table dont les noms de colonnes sont des paramètres
    Par Mythrandil dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 08/09/2007, 15h08
  5. Comment créer une Table dans 1 Bdd ACCESS avec Builder??
    Par makandja dans le forum C++Builder
    Réponses: 6
    Dernier message: 17/03/2004, 20h21

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