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

Développement SQL Server Discussion :

variable comme nom de table


Sujet :

Développement SQL Server

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 66
    Par défaut variable comme nom de table
    Bonjour,

    J'essai d'inserer dans une table temporaire la valeur des variables @TABLE et @TABLE où @TABLE est aussi le nom d'unetable. Code ci-après

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    INSERT #TABLE 
    SELECT  @TABLE,
    	@COLUM 
    from @TABLE 
    where @COLUM like '%text%'
    Le problème est que SQL Server refuse de prendre @TABLE comme valeur pour la table (from @TABLE )

    Cordialement
    Battl14

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 995
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 995
    Billets dans le blog
    6
    Par défaut
    Vous ne pouvez pas passer en paramètre un nom d'objet table, colone, procédure...

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 66
    Par défaut
    Merci de la réponse mais alors comment faire pour récupérer le nom des tables et des champs qui contiendrait un texte recherché?

  4. #4
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Avec la procédure stockée qu'à écrit SQLPro à cet effet (SP_SEARCH_STRING_ANYFIELD_ANYTABLE)

    @++

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    66
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 66
    Par défaut
    J'ai trouver la solution:


    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
    57
    SELECT  sys.objects.name+'.'+sys.all_columns.name tablecolumname,
    		sys.objects.name tablename,
    		sys.all_columns.name columname, 
    		0 AS OK, 
    		0 AS EXIST 
    INTO #IN_SCHEMA
       FROM         sys.objects INNER JOIN
                    sys.all_columns ON sys.objects.object_id = sys.all_columns.object_id INNER JOIN
                    INFORMATION_SCHEMA.TABLES ON INFORMATION_SCHEMA.TABLES.TABLE_NAME = sys.objects.name INNER JOIN
                    sys.types ON sys.all_columns.user_type_id = sys.types.user_type_id
    WHERE       (INFORMATION_SCHEMA.TABLES.TABLE_TYPE = 'BASE TABLE') AND 
    			(INFORMATION_SCHEMA.TABLES.TABLE_NAME IS NOT NULL) AND 
                (sys.types.name NOT IN ('int', 'datetime', 'bit', 'smallint', 'decimal', 'bigint', 'smalldatetime', 'numeric', 'tinyint', 'float','varbinary','binary', 'sysname', 'image'))
    ORDER BY tablecolumname
    
    
    DECLARE @TABLE nvarchar(400),
    		@COLUM nvarchar(400),
    		@TABLECOLUM nvarchar(400),
    		@SQL nvarchar(4000),
    /********************************************************************************
    REQUETE
    ********************************************************************************/
    -- Début de la boucle de traitement des données
    
    WHILE EXISTS(SELECT  * 
    			 from #IN_SCHEMA 
                 WHERE  OK = 0)
    BEGIN
    
       SET @TABLE = (SELECT TOP 1 tablename
                   FROM   #IN_SCHEMA WHERE OK = 0
                   ORDER  BY tablecolumname);
    SET @COLUM = (SELECT TOP 1 Columname
                   FROM   #IN_SCHEMA WHERE OK = 0
                   ORDER  BY tablecolumname);
    SET @TABLECOLUM = (SELECT TOP 1 TableColumname
                   FROM   #IN_SCHEMA WHERE OK = 0
                   ORDER  BY tablecolumname);
    
    ------------------------------------------------------------------------------------
    SET @SQL=N'
    UPDATE #IN_SCHEMA 
    SET EXIST = 1
    WHERE  tablecolumname = '''+@TABLECOLUM+''' and (SELECT  count (*)
    from '+@TABLE+' 
    where '+@COLUM+' like '+'''%texte recherché%'')> 0'
    ---------------------------------------------------------------------------------
    EXEC (@SQL)
    
    UPDATE #IN_SCHEMA
       SET    OK = 1
       WHERE  tablecolumname = @TABLECOLUM
    
    end
    
    Select* from #IN_SCHEMA where EXIST = 1 order by tablecolumname

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 19/05/2014, 11h10
  2. Utiliser une variable comme nom de table Access dans une requête SQL
    Par stsym dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 09/10/2011, 17h11
  3. Réponses: 2
    Dernier message: 12/04/2011, 09h21
  4. donner la valeur d'une variable comme nom de table
    Par cladsam dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 14/10/2005, 15h16
  5. [curseurs] utiliser une variable comme nom de champ
    Par Christian31 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 09/09/2005, 14h12

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