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 :

Fonction retourne varchar > 8000


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Septembre 2003
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Septembre 2003
    Messages : 21
    Par défaut Fonction retourne varchar > 8000
    Bonjour tout le monde,

    Afin d'éditer un document comportant des champs de fusion, j'ai créé une fonction SQL qui récupère et concatène les valeurs de la base de données.
    Mon problème est que dans certains cas la fonction me retourne une valeur supérieure à 8000. J'ai lu sur le forum qu'il fallait utiliser la syntaxe
    varchar (max), mais je n'arrive pas à compiler ma fonction en utilisant cette déclaration .

    De plus, pour le moment je suis sur un SQL Server 2000, mais dans les mois à venir, nous allons migrer sur un 2005, puis un 2008 (peut être ), je voudrais donc une solution qui puisse fonctionner dans les différentes versions si possible.

    Voilà le squelette de ma fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE	FUNCTION  dbo.GetPublicationListe (@PK_IDAffaire uniqueidentifier)
    RETURNS  VARCHAR(8000)
    AS
    BEGIN
     
    DECLARE		
      @strListePublication	VARCHAR(8000),
      SET @strListePublication = ''
     
      [ // Concaténation des données dans la variable @strListePublication
      SET @strListePublication = @strListePublication + @Valeur_du_Curseur ]
     
      RETURN @strListePublication
    END
    J'ai essayé en remplaçant la valeur 8000 par max, mais dans ce cas là j'obtiens "syntaxe incorrecte vers 'max'." lors de la compile.

    Merci d'avance pour vos réponses,
    BibiSeal

  2. #2
    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,

    Effectivement les chaînes de caractère de type CLOB ne sont disponibles sous SQL Server 2000 qu'avec le type de données TEXT, et je doute que vous puissiez l'utiliser pour une fonction.

    Sous SQL Server 2005 et 2008, ce type de données est déprécié et remplacé par VARCHAR(MAX), ce qui permet en outre d'éviter certaines lourdeurs dues au type TEXT. Cela explique pourquoi vous obtenez une erreur de syntaxe

    Il serait donc plus intéressant pour vous de procéder à cette concaténation du côté de votre applicatif en attendant de passer sous SQL Server 2005 ou 2008

    @++

  3. #3
    Membre averti
    Inscrit en
    Septembre 2003
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Septembre 2003
    Messages : 21
    Par défaut
    Bonjour,

    Tout d'abord merci beaucoup de votre réponse et de la rapidité de celle-ci.

    Suite à votre explication, je vais suivre le conseil et effectuer la concaténation dans l'applicatif, en attendant l'upgrade de SQL Server .

    Encore merci et bonne continuation.

    A bientôt.

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

Discussions similaires

  1. Fonction retournant un pointeur
    Par Le Furet dans le forum C
    Réponses: 8
    Dernier message: 25/09/2005, 18h54
  2. Fonction retournant la partie entière d'un nombre
    Par annedjomo dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 12/11/2004, 15h58
  3. fonction retournant une valeur
    Par ryan dans le forum ASP
    Réponses: 4
    Dernier message: 06/09/2004, 17h45
  4. Declaration de fonction retournant un pointeur sur fonction
    Par pseudokifaitladifférence dans le forum C
    Réponses: 5
    Dernier message: 11/08/2003, 19h37
  5. [Manip de fichiers] Fonction retournant des infos
    Par sans_atouts dans le forum C
    Réponses: 3
    Dernier message: 24/07/2002, 14h16

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