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 :

[DEBUTANT] utilisation fonction


Sujet :

MS SQL Server

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2006
    Messages : 142
    Points : 77
    Points
    77
    Par défaut [DEBUTANT] utilisation fonction
    Bonjour, J'essaye depuis ce matin de faire fonctionner une fonction. Cette fonction (récupérée grace à SQLpro dans l'aide de SQL Server) permet de récupérer le numéro de la semaine à partir d'une date donnée.

    Cependant, je ne sais pas comment utiliser, visionner le résultat. Selon moi il faut executer la création de 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
    15
    16
    17
    CREATE FUNCTION ISOweek12  (@DATE datetime)
    RETURNS int
    AS
    BEGIN
       DECLARE @ISOweek int
       SET @ISOweek= DATEPART(wk,@DATE)+1
          -DATEPART(wk,CAST(DATEPART(yy,@DATE) AS CHAR(4))+'0104')
    --Special cases: Jan 1-3 may belong to the previous year
       IF (@ISOweek=0) 
          SET @ISOweek=dbo.ISOweek(CAST(DATEPART(yy,@DATE)-1 
             AS CHAR(4))+'12'+ CAST(24+DATEPART(DAY,@DATE) AS CHAR(2)))+1
    --Special case: Dec 29-31 may belong to the next year
       IF ((DATEPART(mm,@DATE)=12) AND 
          ((DATEPART(dd,@DATE)-DATEPART(dw,@DATE))>= 28))
          SET @ISOweek=1
       RETURN(@ISOweek)
    END
    Puis, pour tester la fonction, faire quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Select ISOweek("01/01/2007")
    Mais j'obtient :
    Msg 195, Niveau 15, État 10, Ligne 1
    'ISOweek' n'est pas une option nom de fonction intégrée reconnue.
    Comment peut on récupérer le résultat d'une fonction ?

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2007
    Messages : 46
    Points : 58
    Points
    58
    Par défaut Re
    Bonjour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT dbo.ISOweek12('08/06/2007')

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2007
    Messages : 46
    Points : 58
    Points
    58
    Par défaut Re(2)
    Tu peux utiliser cette fonction interne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DATEPART(WW,'08/06/2007')
    Voici un bout de l'aide de m$
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Partie de date  Abréviations  
    year                yy, yyyy
    quarter            qq, q
    month             mm, m
    dayofyear        dy, y
    day                dd, d
    week              wk, ww
    weekday         dw
    hour               hh
    minute            mi, n
    second           ss, s
    millisecond      ms

  4. #4
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2006
    Messages
    142
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2006
    Messages : 142
    Points : 77
    Points
    77
    Par défaut
    Je souhaite utiliser la numérotation des semaines version ISO et non américaine, la dexuième solution utilise le standard US ... Voila voila. Mais le select avec le "dbo." fonctionne parfaitement!
    (la différence se voit par exemple si on fait un test sur le 1er janvier 2005 :
    semaine 1 pour les américains
    semaine 53 de l'année précédante pour ISO (france comprise)

    enfin, en tout cas merci !

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

Discussions similaires

  1. [debutant] utilisation d'une fonction predefini "count"
    Par le_voisin dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 03/07/2007, 06h22
  2. [GIMP] [Script-FU] Utilisation fonction gimp-curves-spline
    Par narmataru dans le forum Autres langages
    Réponses: 1
    Dernier message: 09/02/2005, 17h25
  3. [Débutant] Aide utilisation fonctions :(
    Par trakiss dans le forum Débuter
    Réponses: 10
    Dernier message: 27/08/2004, 15h59
  4. Utilisation fonction définie dans un .Dll
    Par jeab. dans le forum Windows
    Réponses: 5
    Dernier message: 23/03/2004, 16h23
  5. [debutant]la fonction scanf
    Par kalaka dans le forum C
    Réponses: 7
    Dernier message: 01/07/2003, 15h15

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