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 :

Insérer plusieurs images à partir d'un dossier [2008R2]


Sujet :

Développement SQL Server

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2015
    Messages : 6
    Points : 5
    Points
    5
    Par défaut Insérer plusieurs images à partir d'un dossier
    C'est quoi le problème dans cette requette?

    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
    DECLARE @sql NVARCHAR(MAX)
    DECLARE @Path VARCHAR(MAX)
    DECLARE @Code NVARCHAR(MAX)
    DECLARE @max int
    SET @Path = 'C:/Users//HP/Pictures/fotos/'
    SET @Code = '1'
    SET @max = 7
     
    WHILE @Code < @max
    BEGIN
    SET @sql = ' 
    			UPDATE [BDD_Loc].[dbo].[employe]
    			SET   Photo = (SELECT * FROM Openrowset
                                                                                      ( Bulk '+@Path+@Code+'.jpg'''' , Single_Blob)
                                                                                      as image
                                                   )
                            WHERE Matricule =  @code 
                    '
    SET @code = convert(int,@Code)+1
    EXEC sp_executesql @sql
    END

    l'erreur qui s'affiche:
    Msg*102, Niveau*15, État*1, Ligne*4
    Syntaxe incorrecte vers 'C:'.

  2. #2
    Membre confirmé
    Homme Profil pro
    Expert SQL Server
    Inscrit en
    Août 2009
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Expert SQL Server

    Informations forums :
    Inscription : Août 2009
    Messages : 61
    Points : 454
    Points
    454
    Par défaut
    Citation Envoyé par miiimaaa1 Voir le message
    C'est quoi le problème dans cette requette?

    DECLARE @sql NVARCHAR(MAX)
    DECLARE @Path VARCHAR(MAX)
    DECLARE @Code NVARCHAR(MAX)
    DECLARE @max int
    SET @Path = 'C:/Users//HP/Pictures/fotos/'
    SET @Code = '1'
    SET @max = 7

    WHILE @Code < @max
    BEGIN
    SET @sql = '
    UPDATE [BDD_Loc].[dbo].[employe]
    SET Photo = (SELECT * FROM Openrowset
    ( Bulk '+@Path+@Code+'.jpg'''' , Single_Blob)
    as image
    )
    WHERE Matricule = @code
    '
    SET @code = convert(int,@Code)+1
    EXEC sp_executesql @sql
    END


    l'erreur qui s'affiche:


    Msg*102, Niveau*15, État*1, Ligne*4
    Syntaxe incorrecte vers 'C:'.
    Essayez dans un premier temps de doubler les quotes dans la chaine de caractère du SQL dynamique.
    Mais pour ce genre de choses, SSIS fonctionne très bien, avec l'objet Import Column.

    Cdlt
    Christophe
    Christophe LAPORTE | Independent Consultant & Trainer
    SQL Server Certified Master | Azure Solution Architect

  3. #3
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 147
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 147
    Points : 7 392
    Points
    7 392
    Billets dans le blog
    1
    Par défaut
    Ça devrait aller mieux :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ( Bulk '''+@Path+@Code+'.jpg'''' , Single_Blob)
    On ne jouit bien que de ce qu’on partage.

  4. #4
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2015
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Nom : Erreur.PNG
Affichages : 230
Taille : 44,8 Ko

  5. #5
    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 : 42
    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
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Pour débugger du code dynamique, le mieux est d'imprimer la chaîne d'instruction qui est soumise au moteur, ou de les stocker dans une table de façon à pouvoir les revoir à posteriori.

    Il vous manquait des quotes à gauche du chemin du fichier, et il y en avait trop à droite de celui-ci.
    Par ailleurs l'incrémentation de la variable @code doit être faite après exécution de la chaîne : après le EXEC sp_executesql.

    Ensuite il faut passer la valeur de la variable @code à la chaîne d'instruction, sans quoi la clause WHERE de l'UPDATE n'est pas valide.

    Voici le code que j'ai testé :

    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
    DECLARE @sql NVARCHAR(MAX)
    	, @Path varchar(max) = 'D:\Users\HP\pictures\fotos\'
    	, @Code nvarchar(max) = '1'
    	, @max int = 7
     
    WHILE @Code < @max
    BEGIN
    	SET @sql = '
    	UPDATE [BDD_Loc].[dbo].[employe]
    	SET Photo = (
    		SELECT	*
    		FROM	OPENROWSET (BULK ''' + @Path + @Code + '.png'', SINGLE_BLOB) AS img
    		)
    	WHERE	Matricule = @code
    	'
     
    	PRINT @sql
     
    	EXEC sp_executesql
    		@sql
    		, N'@code nvarchar(max)'
    		, @code = @Code
     
    	SET @code += 1
    END
    Un peu de lecture ici

    @++

  6. #6
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2015
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 32
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2015
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Bonjour,
    Merciiiiii beaucoup pour votre aide, ça marche à merveille.
    Résolu
    @++

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

Discussions similaires

  1. [2008R2] Insérer plusieurs images dans sql server à partir d'un dossier
    Par miiimaaa1 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 27/05/2015, 14h09
  2. selection d'une liste d'image à partir d'un dossier
    Par bachboucha dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 05/11/2008, 15h41
  3. Réponses: 4
    Dernier message: 25/08/2008, 17h36
  4. Modif à un tutoriel j'ai trouvé : Loader mes images à partir d'un dossier externe
    Par Renegade_Mtl dans le forum ActionScript 1 & ActionScript 2
    Réponses: 1
    Dernier message: 02/04/2008, 07h05
  5. Insérer une image à partir d'un fichier .jar
    Par gege87270 dans le forum Forms
    Réponses: 0
    Dernier message: 30/11/2007, 11h26

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