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 :

Requête selon cycles (dates)


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Homme Profil pro
    web entrepreneur
    Inscrit en
    Novembre 2012
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations professionnelles :
    Activité : web entrepreneur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 117
    Points : 67
    Points
    67
    Par défaut Requête selon cycles (dates)
    Bonjour,

    J'ai une requête qui doit avoir comme critère un cycle (une période).
    Ce cycle est compris entre chaque dimanche 23h59.

    Il s'agit donc de définir tout ce qui est au-delà du dernier dimanche 23h59... mais je cale.

    Merci de votre aide

  2. #2
    Invité
    Invité(e)
    Par défaut
    Une requete de ce type correspondrait-elle ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT Interval = DATEDIFF(week, date_reference, '20120101') FROM nom_table
    Ici on va obtenir le nombre de semaine d'écart d'une date présente dans une table avec une date de référence.
    Sinon il serait peut-être intéressant de nous exposer quelles sont les données en entrée fournies et l'objectif de cette requête pour obtenir une réponse plus proche de votre besoin.

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

    Il s'agit donc de définir tout ce qui est au-delà du dernier dimanche 23h59
    Donc il s'agit du Lundi, à minuit. Ce qui permet d'écrire, sous SQL Server 2008 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SET LANGUAGE 'French'
     
    DECLARE @lundi_dernier date = DATEADD(day, -DATEPART(weekday, GETDATE()) + 1, GETDATE())
     
    SELECT	desColonnes
    FROM	dbo.uneTable
    WHERE	laColonneDate >= @lundi_dernier
    Et sous SQL Server 2005 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SET LANGUAGE 'French'
     
    DECLARE @lundi_dernier datetime
    SELECT	@lundi_dernier = CAST(FLOOR(CAST(DATEADD(day, -DATEPART(weekday, GETDATE()) + 1, GETDATE()) AS float)) AS datetime)
     
    SELECT	desColonnes
    FROM	dbo.uneTable
    WHERE	laColonneDate >= @lundi_dernier
    @++

  4. #4
    Membre du Club
    Homme Profil pro
    web entrepreneur
    Inscrit en
    Novembre 2012
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations professionnelles :
    Activité : web entrepreneur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 117
    Points : 67
    Points
    67
    Par défaut
    J'arrive à bien isoler le cycle de cette manière :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SET              DATEFIRST 1
                              SELECT     TOP (100) PERCENT settledDate, fullMarketName, betId, commissionRate
                               FROM         dbo.bfGetAccountStatement
                               GROUP BY settledDate, fullMarketName, betSize, betId, commissionRate
                               HAVING      (commissionRate <> N'NA') AND (betSize = 0) AND (settledDate > CAST(FLOOR(CAST(GETDATE() AS FLOAT)) AS DATETIME) - (DATEPART(dw, GETDATE()) 
                                                      - 1))
                               ORDER BY settledDate DESC
    Mais lorsque je veux sauvegarder la requête, j'ai le message "Incorrect syntax near the keyword 'SET' ".
    Idem avec SET LANGUAGE 'French'.

    Si je ne mets pas SET DATEFIRST 1, le premier jour de la semaine est le dimanche.

  5. #5
    Membre du Club
    Homme Profil pro
    web entrepreneur
    Inscrit en
    Novembre 2012
    Messages
    117
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations professionnelles :
    Activité : web entrepreneur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2012
    Messages : 117
    Points : 67
    Points
    67
    Par défaut
    J'ai contourné le problème pour le moment en mettant la base en français.

    Comme la question à l'origine de ce post est résolue, j'ai créé un autre topic relatif au problème lié à l'ajout de 'SET...' :
    http://www.developpez.net/forums/d12...d/#post7048970

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

Discussions similaires

  1. Requête selon date du Jour
    Par lanainejulie dans le forum Langage SQL
    Réponses: 5
    Dernier message: 18/04/2011, 12h06
  2. [AC-2000] Requête : appliquer le bon tarif selon la date
    Par kerseb dans le forum Modélisation
    Réponses: 7
    Dernier message: 31/12/2010, 13h18
  3. [Requête] fonction vrai/faux selon une date
    Par syldudu dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 18/12/2006, 10h12
  4. Formulation de la requête liée à la date
    Par wperle dans le forum Langage SQL
    Réponses: 8
    Dernier message: 25/11/2005, 15h37
  5. [JDBC] Requête avec une date sous la forme dd/MM/yyyy
    Par sylviefrfr dans le forum JDBC
    Réponses: 6
    Dernier message: 12/11/2005, 09h35

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