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 :

Supprimer une image dans une table SQL Serveur 2000


Sujet :

MS SQL Server

  1. #1
    Membre confirmé Avatar de Soobook
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2005
    Messages
    98
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Réunion

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2005
    Messages : 98
    Par défaut Supprimer une image dans une table SQL Serveur 2000
    Bonjour,

    J'administre une application de création de vêtements liée une base SQL serveur 2000. La croissance en taille de celle-ci est très importante car l'application y stocke les apperçus (en jpg et wmf) des diverses illustrations contenue dans le logiciel. Ces apperçus représente 80% de la base, or les plus anciens peuvent être supprimés sans problème.

    La table contenant ces images est composée de trois colonnes:
    -l'identifiant unique de l'image (imageserialnumber)
    -sa taille (imagesize)
    -l'image elle-même (imageblob)

    Pour les entrées qui ne sont plus nécessaires, je souhaite "vider" les cellules imagesize et imageblob, mais conserver la ligne et l'imageserialnumber afin que l'entrée puisse être régénérée si besoin.
    j'ai donc essayé une requête de ce type (null est autorisé sur les deux champs concernés):

    UPDATE table
    SET table.imagesize = null,
    table.imageblob = null
    WHERE table.imageserialnumber in (SELECT ...)

    Je suis sûr de mon SELECT, et cela fonctionne pour imagesize, mais dans imageblob la donnée est toujours présente (représentée par : <Binaire> ).
    Si j'essaye de supprimer la donnée manuellement directement dans la table, SQL m'affiche le message "Impossible d'éditer cette cellule".

    J'en arrive donc à ma question: comment fait-on pour effacer une image contenue dans une table SQL?

    Merci par avance.

    Soobook...

  2. #2
    Membre émérite
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Août 2006
    Messages
    730
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2006
    Messages : 730
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    UPDATE table
    SET table.imagesize = null,
    table.imageblob = null
    WHERE table.imageserialnumber in (SELECT ...)
    tu y étais presque, il te manque le convert

    UPDATE table
    SET table.imagesize = null,
    table.imageblob = convert(image,null)
    WHERE table.imageserialnumber in (SELECT ...)


    A+
    serge

  3. #3
    Membre confirmé Avatar de Soobook
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2005
    Messages
    98
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Réunion

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2005
    Messages : 98
    Par défaut ça marche!!!
    Merci beaucoup pour ton aide Serge, ça marche effectivement très bien désormais.

    Une petite précision pour les personnes qui rencontreraient le même problème que moi: la place libérée par la suppression des images est convertie en espace vide dans la base de donnée qui ne réduit donc pas, et grossie même un peu. Il faut donc la compacter par la suite.

    Au final, la requête ressemble à ça :

    UPDATE table
    SET table.imagesize = null,
    table.imageblob = CONVERT(image, null)
    WHERE table.imageserialnumber in (SELECT ...)
    DBCC SHRINKDATABASE (nom_de_la_base)

    Merci encore à Serge...

    Soobook...

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

Discussions similaires

  1. [Débutant] Manipulation d'images : intégrer une image dans une image
    Par noscollections dans le forum VB.NET
    Réponses: 2
    Dernier message: 17/10/2014, 11h51
  2. Réponses: 2
    Dernier message: 27/10/2010, 20h38
  3. Mettre une Image dans une Image
    Par shadowhocine dans le forum SWT/JFace
    Réponses: 2
    Dernier message: 19/12/2006, 18h40
  4. Réponses: 3
    Dernier message: 30/10/2006, 11h21
  5. Insérer une légende dans une image avec une police plus petite
    Par Paulinho dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 3
    Dernier message: 29/04/2006, 14h19

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