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

Contribuez Discussion :

Rechercher des périodes vérifiant un critère sur des dates consécutives


Sujet :

Contribuez

  1. #1
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 945
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 945
    Points : 58 592
    Points
    58 592
    Billets dans le blog
    46
    Par défaut Rechercher des périodes vérifiant un critère sur des dates consécutives
    Bonjour à tous,

    Je viens de retrouver une archive d’un ancien problème que je voudrais vous soumettre comme contribution…

    Pour simplifier, je prends une table de cotation comprenant les cours d’un certain nombre d’actions relevés quotidiennement.


    Le problème : retrouver l’action et la période comprenant le plus grand nombre de jours consécutifs de baisse.
    D’après mon jeu d’essai, je devrais obtenir :


    Pendant cette période l’action ACT1 chute pendant 4 jours consécutivement (passant de 2370 à 2340).

    Alors peut-être existe-t-il de meilleures méthodes pour résoudre ce problème mais pour ma part j’ai dû composer faute de mieux.

    Je commence par une requête intermédiaire R_Variation :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT Cotation.CodeAction,
    Cotation.DateValeur, 
    Cotation.CoursFermeture, 
    nz(
    Cotation.CoursFermeture-
                          (SELECT TOP 1 C.CoursFermeture FROM Cotation C 
                            WHERE C.CodeAction=Cotation.CodeAction 
                                  AND C.DateValeur<Cotation.DateValeur
                            ORDER BY C.DateValeur DESC)
    ,0
    ) AS variation
    FROM Cotation
    ORDER BY Cotation.CodeAction, Cotation.DateValeur;



    La colonne calculée [variation] donne la variation du cours de l’action par rapport à la cotation précédente. La variation peut donc être positive, négative ou nulle.

    Je reprends la requête précédente pour rédiger la requête RNbJoursConsec :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT 
    R_Variation.CodeAction, 
    R_Variation.DateValeur,
     R_Variation.CoursFermeture, 
    R_Variation.variation, 
    nbJoursConsecutifs([R_Variation].[DateValeur],[R_Variation].[CodeAction]) AS joursTendance
    FROM R_Variation;
    qui retourne les lignes suivantes :


    La colonne calculée [JoursTendance] permet de rendre compte des jours consécutifs avec la même tendance. Sa valeur repart à 1 à chaque fois que la colonne [variation] voit son signe changer.

    [JoursTendance] exploite une fonction VBA nommée nbJoursConsecutifs dont je donne le code à recopier dans un module:

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    Public Function nbJoursConsecutifs(DateEnCours As Date, CodeAction As Variant) As Integer
     
    Dim strSQL As String
    Dim tendance As Integer, tendanceprec As Integer
    Dim DatePrec As Date
    Dim rs As DAO.Recordset
     
    strSQL = "SELECT variation, DateValeur FROM R_Variation WHERE DateValeur<=#" & Format(DateEnCours, "mm/dd/yyyy") & "# AND " & _
             "CodeAction='" & CodeAction & "' ORDER BY DateValeur DESC;"
      'Debug.Print strSQL
    Set rs = CurrentDb.OpenRecordset(strSQL)
     
    rs.MoveLast
    ' MsgBox (rs.RecordCount)
    If rs.RecordCount < 2 Then
        nbJoursConsecutifs = 1
    Else
        rs.MoveFirst
        tendance = Sgn(rs.Fields(0))
        rs.MoveNext
        tendanceprec = Sgn(rs.Fields(0))
        DatePrec = rs.Fields(1)
     
    '    MsgBox (DateEnCours & "  " & tendance & "  " & DatePrec & "  " & tendanceprec)
     
        If tendance = tendanceprec Then
              nbJoursConsecutifs = nbJoursConsecutifs(DatePrec, CodeAction) + 1
        Else
         nbJoursConsecutifs = 1
        End If
     
    End If
        rs.Close
    End Function

    Vous noterez en ligne 27, l’appel récursif :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     nbJoursConsecutifs = nbJoursConsecutifs(DatePrec, CodeAction) + 1
    Les choses sont maintenant en place :
    Le problème : retrouver l’action et la période comprenant le plus grand nombre de jours consécutifs de baisse.

    R_Joursdebaisse :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT RNbJoursConsec.CodeAction, 
    DateAdd("d",-JoursTendance+1,DateValeur) AS du, 
    RNbJoursConsec.DateValeur AS au
    FROM RNbJoursConsec
    WHERE RNbJoursConsec.[JoursTendance]=
    (SELECT Max(T.JoursTendance) FROM RNbJoursConsec T WHERE T.variation<0)
     AND RNbJoursConsec.[variation]<0;

    Que l’on adaptera facilement pour obtenir la période comprenant le plus grand nombre de jours consécutifs de hausse d’une action.

    Je mets un fichier de démo en pièce-jointe.

    Vouala…
    Fichiers attachés Fichiers attachés

  2. #2
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    salut f-leb,

    j'ai trouvé le sujet amusant. j'ai donc recherché une solution full sql.
    je n'y ai pas trouvé de grosse difficulté en particulier à réaliser cela.
    quand à coder en vb autant faire un simple parcours dans la requête ordonnée par date, cela me parait plus simple et rapide.

    en tout cas ta méthodologie est bien expliquée.

    bonne continuation,

  3. #3
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    salut Diem ,

    j'ai donc recherché une solution full sql
    On peut la voir ?

    @+

    Philippe

  4. #4
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    salut Philippe ,

    Citation Envoyé par Philippe
    On peut la voir ?
    je sais pas, c'est intime comme question...

    bon, je l'ai refait en détail pour expliquer sinon brut comme ca, ca fait un pavé et ca parait pas aussi simple que ca n'y parait.

    j'ai supposé qu'il pouvait avoir des trous dans entre les enregistrements.
    ce qui veut dire que je recherche :
    la période comprenant le plus grand nombre de jours consécutifs SAISIE de baisse
    ce qui complique un peu le sql sinon un j-1 ou j-2 sur la date simplifierait le sql (d'autant qu'il n'y a pas non plus d'indice ordonné par date des enregistrements)

    Etape 1: trouver les premières variations descendantes
    j'ai opté pour: si la variation du cours à la précédente date est négative et l'antécedant à celle-ci positive

    d'abord le cours précédant <last> et antécédant à celui-ci <prevlast>:
    Code SQL : 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
     
    select
    	t1.*,
     
    	(
    	select
    		c1.coursfermeture
    	from cotation c1
    	where
    		(c1.datevaleur=
    			(
    			select max(c2.datevaleur) from cotation c2
    			where
    				(c2.datevaleur<t1.datevaleur)
    				and
    				(c2.codeaction=t1.codeaction)
    			)
    		)
    		and
    		(c1.codeaction=t1.codeaction)
    	) as last,
     
    	(
    	select
    		c1.coursfermeture
    	from cotation c1
    	where
    		(c1.datevaleur=
    			(
    			select max(c2.datevaleur) from cotation c2
    			where
    				(c2.datevaleur<
    					(
    					select max(c2.datevaleur) from cotation c2
    					where
    						(c2.datevaleur<t1.datevaleur)
    						and
    						(c2.codeaction=t1.codeaction)
    					)
    				)
    				and
    				(c2.codeaction=t1.codeaction)
    			)
    		)
    		and
    		(c1.codeaction=t1.codeaction)
    	) as prevlast
     
    from cotation t1

    les tendances des cours :
    <tlast> = <coursfermeture> inférieur à <last> ?
    <tprevlast> = <last> inférieur à <prevlast> ?
    soit:
    Code SQL : 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
     
    select
    	t1.*,
     
    	(
    	t1.coursfermeture
    	<
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	) as tlast,
     
    	(
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	<
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	) as tprevlast
     
    from cotation t1

    LES PREMIERES TENDANCES A LA BAISSE:
    <isPremDesc> = <tlast> and not <tprevlast>
    adaptées au cas particuliers où dès le départ le cours baisse:
    <isPremDesc> = <tlast> and not nz(<tprevlast>,0)
    soit:
    Code SQL : 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
    18
     
    select
    	t1.*,
     
    	(
    	t1.coursfermeture
    	<
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	)
    	and not
    	(nz(
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	<
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	,0)
    	) as isPremDesc
     
    from cotation t1

    Etape 2: définir la requete [baisse] de l'ensemble des enregistrements des premières baisses: (en vue de récupérer la date pour chaque enregistrement)
    un truc du genre:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from cotation where <isPremDesc>
    soit:
    Code SQL : 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
     
    select
    	t1.*
    from cotation t1
    where
    	(
    	t1.coursfermeture
    	<
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	)
    	and not
    	(nz(
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	<
    	(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    	,0)
    	)

    Etape 3: récapitulatif des baisses
    requete [récapitulatif] de cotation avec: <du> la date de la baisse et <nbJCDesc> le nombre consécutif de jour de baisse
    <du> = date la plus proche inférieur dans [baisse] et où <tlast> est une baisse
    <nbJCDesc> = <datevaleur> - <du>
    soit:
    Code SQL : 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    select
    	t2.*,
     
    	(
    	select
    		max(t1.datevaleur)
    	from cotation t1
    	where
    		(
    		t1.coursfermeture
    		<
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    		)
    		and not
    		(nz(
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    		<
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    		,0)
    		)
    		and
    		(t1.codeaction=t2.codeaction)
    		and
    		(t1.datevaleur<=t2.datevaleur)
    		and
    		(
    		t2.coursfermeture
    		<
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t2.datevaleur) and (c2.codeaction=t2.codeaction))) and (c1.codeaction=t2.codeaction))
    		)
    	) as du,
     
    	(t2.datevaleur-du+1) as nbJCDesc
     
    from cotation t2

    Etape 4-Finale: Retrouver l’action et la période comprenant le plus grand nombre de jours consécutifs de baisse.
    et bien avec la requete de récapitulatif des baisses cela parait simple, non?
    un truc du genre:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    select top 1 * from [recapitulatif] order by nbJCDesc desc
    he bien non, ca marche pas... si l'enregistrement est bien choisi, les champs calculé <de> et <nbJCDesc> sont vide... merci ACCESS...
    donc reste plus qu'à faire un sql du genre:
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from [recapitulatif] where nbJCDesc=(select max(nbJCDesc) from [recapitulatif])
    bon c'est vrai aussi que c'est plus correcte s'il y a plusieurs actions dont <nbJCDesc> est max.

    réadaption [recapitulatif] pour avoir uniquement le max(nbJCDesc):
    (nos amis sqlien des autres moteurs rigoleraient bien parce qu'il peuvent normalement faire des alias des requetes existants et les reprendres dans le même sql sans avoir à les réécrire...)
    Code SQL : 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    select
    	max(
    	(
    	select
    		t2.datevaleur-max(t1.datevaleur)+1
    	from cotation t1
    	where
    		(
    		t1.coursfermeture
    		<
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    		)
    		and not
    		(nz(
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    		<
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    		,0)
    		)
    		and
    		(t1.codeaction=t2.codeaction)
    		and
    		(t1.datevaleur<=t2.datevaleur)
    		and
    		(
    		t2.coursfermeture
    		<
    		(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t2.datevaleur) and (c2.codeaction=t2.codeaction))) and (c1.codeaction=t2.codeaction))
    		)
    	)
    	) as nbJCDesc
    from cotation t2

    soit la requete finale:
    Code SQL : 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
     
    select
    	tf.codeaction,
    	tf.du,
    	tf.datevaleur as au,
    	tf.nbJCDesc
    from
    	(
    	select
    		t2.*,
     
    		(
    		select
    			max(t1.datevaleur)
    		from cotation t1
    		where
    			(
    			t1.coursfermeture
    			<
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    			)
    			and not
    			(nz(
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    			<
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    			,0)
    			)
    			and
    			(t1.codeaction=t2.codeaction)
    			and
    			(t1.datevaleur<=t2.datevaleur)
    			and
    			(
    			t2.coursfermeture
    			<
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t2.datevaleur) and (c2.codeaction=t2.codeaction))) and (c1.codeaction=t2.codeaction))
    			)
    		) as du,
     
    		(t2.datevaleur-du+1) as nbJCDesc
     
    	from cotation t2
    	) tf
     
    where
    	tf.nbJCDesc =
    	(
    	select
    		max(
    		(
    		select
    			t2.datevaleur-max(t1.datevaleur)+1
    		from cotation t1
    		where
    			(
    			t1.coursfermeture
    			<
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    			)
    			and not
    			(nz(
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    			<
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t1.datevaleur) and (c2.codeaction=t1.codeaction))) and (c2.codeaction=t1.codeaction))) and (c1.codeaction=t1.codeaction))
    			,0)
    			)
    			and
    			(t1.codeaction=t2.codeaction)
    			and
    			(t1.datevaleur<=t2.datevaleur)
    			and
    			(
    			t2.coursfermeture
    			<
    			(select c1.coursfermeture from cotation c1 where (c1.datevaleur=(select max(c2.datevaleur) from cotation c2 where (c2.datevaleur<t2.datevaleur) and (c2.codeaction=t2.codeaction))) and (c1.codeaction=t2.codeaction))
    			)
    		)
    		)
    	from cotation t2
    	)

    voilà à quoi j'ai pensé rapidement comme solus,

  5. #5
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 945
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 945
    Points : 58 592
    Points
    58 592
    Billets dans le blog
    46
    Par défaut
    rahhh l’est fort le Vodiem, encore une rasta-requête de compet

    Un petit souci cependant car le fait qu’il peut y avoir des jours sans cotation change un peu la donne…

    Je précise le cahier des charges avec un jeu de données modifié :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CodeAction	DateValeur	CoursFermeture
    ACT1 	      10/07/2010   	   2370
    ACT1 	      11/07/2010   	   2360
    ACT1 	      13/07/2010   	   2318
    ACT1 	      15/07/2010   	   2312
    ACT1 	      22/07/2010   	   2350
    ACT2 	      05/07/2010   	   4030
    ACT2 	      06/07/2010   	   3950
    ACT2 	      12/07/2010   	   3920
    Ta requête, Vodiem, retourne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    codeaction	du	au
    ACT2 	06/07/2010 	12/07/2010
    Car cette période de baisse dure 7 jours mais elle ne comprend que 2 séances de cotation (les 06 et 12/07/2010)

    Or, j’aimerais qu’elle retourne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    CodeAction	du	au
    ACT1 	11/07/2010 	15/07/2010
    La période de baisse ne dure que 5 jours mais elle comprend 3 séances à la baisse (les 11, 13 et 15/07/2010)

    Le problème devient :
    retrouver l’action et la période comprenant le plus grand nombre de séances consécutives de baisse.

    Je regarde à comment adapter ma méthode.
    Je ne doute pas que tu réussisses à adapter ton SQL en conséquence…

    A plus tard…

  6. #6
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    Citation Envoyé par f-leb
    Un petit souci cependant car le fait qu’il peut y avoir des jours sans cotation change un peu la donne…
    je sais pas mais je m'y attendais à celle là...

    Citation Envoyé par f-leb
    Le problème devient :
    retrouver l’action et la période comprenant le plus grand nombre de séances consécutives de baisse.
    mon avis que c'est pas ca que tu veux...
    sinon le résultat d'après le dernier exemple ne serait pas du 11/07/2010 au 15/07/2010, vu que les séances ne sont pas consécutives. ;P
    je me permets de reformuler ton idée:
    retrouver l'action et la période qui a la plus grande période de baisse avec le plus grand nombre de séance.

    mais même avec ca:
    qu'es ce qui est plus représentatif? une grande période avec une faible densité ou une petite période à grande densité?
    je dirais même : à quel moment l'un prévaut sur l'autre?

    par exemple:
    légende:
    B: jour de baisse
    -: pas de saisie
    N/X: N jours de baisse / X valeur saisie sur la période

    7/4: B--BB-B
    5/5: BBBBB
    6/5: BBBB-B
    15/4: B---B---B-----B
    15/5: BB----------BBB

    lequel est le plus représentatif de la baisse? quel est la formulation la plus pertinente dans tous les cas de figure?


  7. #7
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 945
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 945
    Points : 58 592
    Points
    58 592
    Billets dans le blog
    46
    Par défaut
    Bonjour Vodiem,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    7/4: B--BB-B
    5/5: BBBBB
    6/5: BBBB-B
    15/4: B---B---B-----B
    15/5: BB----------BBB

    J’aimerais que la requête ne retourne que les lignes 2,3 et 5 parce qu’elles comportent 5 séances de baisse à suivre alors que les lignes 1 et 4 n’en comportent que quatre (la durée en nombre de jours de la baisse m’importe peu en fait parce que les "trous" sont rares).
    Par contre j’ai besoin de savoir quand a débuté la baisse et quand elle se termine.

    Pour tenir compte des quelques jours sans séance de cotation, il faut juste modifier ma dernière requête R_Joursdebaisse comme suit :

    R_Joursdebaisse :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    SELECT RNbJoursConsec.CodeAction, 
    (
        SELECT Max(U.DateValeur) FROM RNbJoursConsec U
        WHERE U.CodeAction=RNbJoursConsec.CodeAction
        AND U.DateValeur<=RNbJoursConsec.DateValeur
        AND U.JoursTendance=1
    )  AS du,
    RNbJoursConsec.DateValeur AS au
    FROM RNbJoursConsec
    WHERE RNbJoursConsec.JoursTendance=(SELECT Max(T.JoursTendance) FROM RNbJoursConsec T WHERE T.variation<0) AND RNbJoursConsec.variation<0;

    Merci de ton intérêt pour cet exercice amusant

  8. #8
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    bon, comme tu voudras...

    20/4: B---B-----B--------B
    5/3: B-B-B

    tu es conscient que 20/4 sera le résultat ?
    je décline toute responsabilité quand à l'exploitation de la requête...
    c'est à tes risques et péril, tu me signe une décharge... t'es conscient au moins que tu joues avec la bourse???

    d'un autre côté ca me facilite le travaille, j'en étais à conjecturer des formules savante pour valoriser la distribution des points dans l'espace... encore un mystère qui ne sera pas élucidé ce soir...

    Code SQL : 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    SELECT
    	tf.codeaction,
    	tf.du,
    	tf.datevaleur AS au
    FROM
    	(
    	SELECT
    		t2.*,
     
    		(
    		SELECT
    			max(t1.datevaleur)
    		FROM cotation t1
    		WHERE
    			(
    			t1.coursfermeture
    			<
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    			)
    			AND NOT
    			(nz(
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    			<
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    			,0)
    			)
    			AND
    			(t1.codeaction=t2.codeaction)
    			AND
    			(t1.datevaleur<=t2.datevaleur)
    			AND
    			(
    			t2.coursfermeture
    			<
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t2.datevaleur) AND (c2.codeaction=t2.codeaction))) AND (c1.codeaction=t2.codeaction))
    			)
    		) AS du
     
    	FROM cotation t2
    	) tf
     
    WHERE
    	(select count(*) from cotation c1 where (c1.datevaleur between du and tf.datevaleur) and (c1.codeaction=tf.codeaction)) =
    	(
    	SELECT
    		max(nbJCDescSaisie)
    	FROM
    		(
    		SELECT
    			(select count(*) from cotation c1 where (c1.datevaleur between du and tf.datevaleur) and (c1.codeaction=tf.codeaction)) as nbJCDescSaisie
    		FROM
    			(
    			SELECT
    				t2.*,
     
    				(
    				SELECT
    					max(t1.datevaleur)
    				FROM cotation t1
    				WHERE
    					(
    					t1.coursfermeture
    					<
    					(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    					)
    					AND NOT
    					(nz(
    					(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    					<
    					(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    					,0)
    					)
    					AND
    					(t1.codeaction=t2.codeaction)
    					AND
    					(t1.datevaleur<=t2.datevaleur)
    					AND
    					(
    					t2.coursfermeture
    					<
    					(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t2.datevaleur) AND (c2.codeaction=t2.codeaction))) AND (c1.codeaction=t2.codeaction))
    					)
    				) AS du
     
    			FROM cotation t2
    			) tf
    		)
    	)

  9. #9
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    Chapeau bas pour vos réalisations

    Dièm, la requête la plus dingue que je n'ai jamais vu sous Access...
    J't'adore !!! (en bonne amitié seulement ...)

    Philippe

  10. #10
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 945
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 945
    Points : 58 592
    Points
    58 592
    Billets dans le blog
    46
    Par défaut
    Citation Envoyé par philben Voir le message
    J't'adore !!! (en bonne amitié seulement ...)
    très touchant

    Exercice résolu, bravo Vodiem

    à bientôt...

  11. #11
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 945
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 945
    Points : 58 592
    Points
    58 592
    Billets dans le blog
    46
    Par défaut
    Bon, revenez je n’ai pas fini !

    Voici un nouveau jeu de données et le nouveau résultat souhaité :


    Vous voyez l’idée, sur la période du 2 au 16/08/2010, l’action ACT3 a chutée de 100 pts sur 4 séances consécutives de baisse.
    Le 06/07/2010, l’action ACT2 a chutée de 80 pts en une seule séance.
    Du 2 au 6/07/2010, l’action ACT1 a chutée de 70 pts sur 4 séances consécutives de baisse.
    Etc…

    Je donnerais ma solution (hybride SQL+VBA) une fois que Vodiem aura pondu sa soluce full SQL en moins de 80 lignes

  12. #12
    Expert confirmé
    Avatar de vodiem
    Homme Profil pro
    Vivre
    Inscrit en
    Avril 2006
    Messages
    2 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Vivre
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 895
    Points : 4 325
    Points
    4 325
    Par défaut
    Citation Envoyé par f-leb
    très touchant
    he oui, on s'adore Philippe et moi
    on se "SQrL" depuis un bout de temps ensemble ;P

    Citation Envoyé par philben
    en bonne amitié seulement
    c'est quoi ce sous entendu? ^^

    Citation Envoyé par f-leb
    une fois que Vodiem aura pondu sa soluce full SQL en moins de 80 lignes
    voilà, le Diem il'a pondu:
    Code SQL : 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    SELECT
    	tf.codeaction,
    	tf.du,
    	max(tf.au) as au,
    	sum(tf.diff) as baisse
    FROM
    	(
    	SELECT
    		t2.codeaction,
    		t2.datevaleur as au,
     
    		(
    		SELECT
    			max(t1.datevaleur)
    		FROM cotation t1
    		WHERE
    			(
    			t1.coursfermeture
    			<
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    			)
    			AND NOT
    			(nz(
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    			<
    			(SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t1.datevaleur) AND (c2.codeaction=t1.codeaction))) AND (c2.codeaction=t1.codeaction))) AND (c1.codeaction=t1.codeaction))
    			,0)
    			)
    			AND
    			(t1.codeaction=t2.codeaction)
    			AND
    			(t1.datevaleur<=t2.datevaleur)
    		) AS du,
     
    		(
    		t2.coursfermeture - (SELECT c1.coursfermeture FROM cotation c1 WHERE (c1.datevaleur=(SELECT max(c2.datevaleur) FROM cotation c2 WHERE (c2.datevaleur<t2.datevaleur) AND (c2.codeaction=t2.codeaction))) AND (c1.codeaction=t2.codeaction))
    		) as diff
     
    	FROM cotation t2
    	) tf
    WHERE tf.diff<0
    GROUP BY tf.codeaction, tf.du
    ORDER BY sum(tf.diff)
    il est encore tout chaud, sortie de l'a... l'a???
    l'adsl, bien sur...

    bonne appétit! ^^

  13. #13
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 945
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 945
    Points : 58 592
    Points
    58 592
    Billets dans le blog
    46
    Par défaut
    Citation Envoyé par vodiem Voir le message
    he oui, on s'adore Philippe et moi
    on se "SQrL" depuis un bout de temps ensemble ;P
    du moment que cette relation est consentie

    Encore une belle requête qui donne bien le résultat souhaité en tout cas.

    Je donne ma solution, histoire de contribuer un peu quand même


    Je reprends ma requête intermédiaire R_Variation du premier message :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT Cotation.CodeAction, Cotation.DateValeur, Cotation.CoursFermeture, nz(
    Cotation.CoursFermeture-(SELECT TOP 1 C.CoursFermeture FROM Cotation C WHERE C.CodeAction=Cotation.CodeAction AND C.DateValeur<Cotation.DateValeur ORDER BY C.DateValeur DESC)
    ,0
    ) AS variation
    FROM Cotation
    ORDER BY Cotation.CodeAction, Cotation.DateValeur;

    Dans la même idée, j’utilise ensuite la requête RSeancesConsec, avec une fonction récursive SeancesConsecutives.

    RSeancesConsecutives :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT R_Variation.CodeAction, R_Variation.DateValeur, R_Variation.CoursFermeture, R_Variation.variation, SeancesConsecutives([R_Variation].[DateValeur],[R_Variation].[CodeAction]) AS PeriodeTendance
    FROM R_Variation;

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    Public Function SeancesConsecutives(DateEnCours As Date, CodeAction As Variant) As Integer
     
    Dim strSQL As String
    Dim tendance As Integer, tendanceprec As Integer
    Dim DatePrec As Date, DateActuelle As Date
    Dim rs As DAO.Recordset
     
    strSQL = "SELECT variation, DateValeur FROM R_Variation WHERE DateValeur<=#" & Format(DateEnCours, "mm/dd/yyyy") & "# AND " & _
             "CodeAction='" & CodeAction & "' ORDER BY DateValeur DESC;"
      'Debug.Print strSQL
    Set rs = CurrentDb.OpenRecordset(strSQL)
     
    rs.MoveLast
     
    If rs.RecordCount < 2 Then
        SeancesConsecutives = 1
    Else
        rs.MoveFirst
        tendance = Sgn(rs.Fields(0))
        DateActuelle = rs.Fields(1)
        rs.MoveNext
        tendanceprec = Sgn(rs.Fields(0))
        DatePrec = rs.Fields(1)
     
        If tendance = tendanceprec Then
              SeancesConsecutives = SeancesConsecutives(DatePrec, CodeAction)
        Else
         SeancesConsecutives = SeancesConsecutives(DatePrec, CodeAction) + 1
        End If
     
    End If
        rs.Close
    End Function
    Voici le résultat intermédiaire obtenu :


    Et la requête finale R_f-leb :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT RSeancesConsec.CodeAction, Min(RSeancesConsec.DateValeur) AS Du, Max(RSeancesConsec.DateValeur) AS Au, Sum(RSeancesConsec.variation) AS Baisse
    FROM RSeancesConsec
    WHERE RSeancesConsec.variation<0
    GROUP BY RSeancesConsec.CodeAction, RSeancesConsec.PeriodeTendance
    ORDER BY Sum(RSeancesConsec.variation);


    Résultat en pièce-jointe où j’ai également inclue la fameuse requête R_Vodiem.

    Je pense que j’en ai maintenant terminé avec cette modeste contribution, à bientôt.
    Fichiers attachés Fichiers attachés

  14. #14
    Rédacteur/Modérateur

    Avatar de User
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    8 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 8 447
    Points : 20 041
    Points
    20 041
    Billets dans le blog
    67
    Par défaut
    Bravo à vodiem et Fabien pour cette contribution

Discussions similaires

  1. [XL-2007] Lecture/écriture sur des fichiers fermés avec critères
    Par webisfun dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 14/03/2012, 11h41
  2. Select avec 2 critères sur des tables reliées
    Par beyo dans le forum Requêtes
    Réponses: 4
    Dernier message: 07/12/2010, 16h03
  3. Requete sur des périodes
    Par fsanna dans le forum Requêtes
    Réponses: 16
    Dernier message: 08/06/2009, 16h55
  4. requête sur des périodes délimitées par des dates
    Par gvdmoort dans le forum Requêtes
    Réponses: 1
    Dernier message: 12/10/2007, 13h09
  5. [Joomla!] critères sur des articles à la manière du ranking
    Par Nillak dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 19/03/2007, 11h33

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