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 :

GetDate comme paramètre d'une fonction


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Inscrit en
    Juin 2006
    Messages
    229
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 229
    Par défaut GetDate comme paramètre d'une fonction
    Bonjour,

    Sous MSSQLServer 2000, pas de GetDate dans une fonction. Jusque là d'accord.

    J'essaye de passer GetDate en paramètre.
    ça fonctionne pour une fonction scalaire mais pas pour une fonction de table.

    Est-ce normal ?

    J'ai cette erreur :
    Ligne 6 : syntaxe incorrecte vers '('.

    lors de l'appel de :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM dbo.F_SEMAINES_AV_AP(GETDATE());
    Je n'ai pas de problème de type, mon paramètre est bien déclaré dans ma fonction.

    Et si je fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    DECLARE @dd AS DATETIME
     
    SET @dd = GETDATE();
     
    SELECT * FROM dbo.F_SEMAINES_AV_AP(@dd);
    ça marche.

    Merci pour vos réponses.

  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 : 44
    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,

    Que ce soit sous SQL Server 2000 ou 2005, les paramètres que tu passe à une fonction ne peuvent que prendre la place de valeurs, et ne peuvent pas être utilisés à la place de noms de tables, de colonnes ou d'autres objets de base de données tels que des fonctions, comme dans ton exemple.
    C'est pour cela que tu es obligé de déterminer la valeur de ton paramètre pour le passer à ta fonction.
    En revanche, tu peux déclarer une valeur par défaut pour les paramètres de ta fonction F_SEMAINES_AV_AP. Dans ton cas tu pourras ainsi appeler la fonction sans paramètres si tu veux la voir fonctionner avec la date courante, soit lui passer une date pour récupérer la valeur qu'il te faut.

  3. #3
    Membre expérimenté
    Inscrit en
    Juin 2006
    Messages
    229
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 229
    Par défaut
    Merci pour cette réponse rapide.

    Pourquoi cet appel fonctionne pour une fonction scalaire de ma base pour laquelle je passe également directement la fonction GETDATE ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT dbo.MA_FONCTION_SCALAIRE(GETDATE())
    ça fonctionne.

    Merci.

  4. #4
    Membre confirmé
    Inscrit en
    Décembre 2004
    Messages
    112
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 112
    Par défaut
    Salut,

    essaye de faire un truc du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM dbo.F_SEMAINES_AV_AP((SELECT GETDATE()));

  5. #5
    Membre expérimenté
    Inscrit en
    Juin 2006
    Messages
    229
    Détails du profil
    Informations forums :
    Inscription : Juin 2006
    Messages : 229
    Par défaut
    Salut,

    C'est pire. En lançant

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM dbo.F_SEMAINES_AV_AP(SELECT GETDATE());
    Maintenant j'ai le message :

    Msg 156, Niveau 15, État 1, Ligne 6
    Syntaxe incorrecte vers le mot clé 'SELECT'.
    Msg 170, Niveau 15, État 1, Ligne 6
    Ligne 6 : syntaxe incorrecte vers ')'.

Discussions similaires

  1. Contruire un array comme paramètre d'une fonction
    Par ctrl+z dans le forum Langage
    Réponses: 2
    Dernier message: 14/04/2008, 15h27
  2. Réponses: 1
    Dernier message: 25/12/2007, 20h22
  3. Passage d'une variable comme paramètre d'une fonction
    Par lowman dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 17/10/2007, 15h12
  4. Passer une matrice comme paramètre d'une fonction
    Par Rniamo dans le forum Langage
    Réponses: 8
    Dernier message: 16/07/2006, 20h55
  5. fonction comme paramètre d'une fonction
    Par velociraptor5679 dans le forum C++
    Réponses: 8
    Dernier message: 17/06/2006, 18h19

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