Accueil > Forum > > > > Calculer des différences sous certaines conditions
Calculer des différences sous certaines conditions
mardi 13 décembre 2005 à 19:24:25 |
Calculer des différences sous certaines conditions

JoeyBlack
|
Bonjour
J'ai une table de type : date Date, valeur Float. J'aimerai créer une
nouvelle table contenant le même type de champs : date Date, valeur2
Float.
Je veux que valeur2(date) = valeur(date)-valeur(date précédente), la
date précédente n'étant pas forcement égale à la date -1 mais est le
maximum des dates précédent la date en question.
Quelqun (un bon ;) )peut-il m'aider à faire une requete rapide a faire sur un nombre important de données (700000) ?
Merci bcp
JoeyBlack
|
|
mardi 13 décembre 2005 à 20:52:16 |
Re : Calculer des différences sous certaines conditions

nhervagault
|
Salut
Peux tu mettre un exemple de temple départ et arrive car un exemple vaut mieux qu'un long discours.
Et mettre le type de base
thanks
|
|
mardi 13 décembre 2005 à 21:37:33 |
Re : Calculer des différences sous certaines conditions

JoeyBlack
|
Départ :
2005-12-02 30.46
2005-12-05 29.95
2005-12-06 30.34
2005-12-07 30.12
2005-12-08 29.81
2005-12-09 29.98
2005-12-12 29.89
Et je veux à l'arrivé :
2005-12-05 -0.51
2005-12-06 0.39
2005-12-07 -0.22
2005-12-08 -0.31
2005-12-09 0.17
2005-12-12 0.09
Par contre je suis un peu débutant dans
tout ce qui est base de données. Le "type" de base je sais pas trop de
quoi tu parles, en tout cas j'utilise MySQL 5.0.
J'espère que c tout ce que tu voulais savoir :S.
|
|
mardi 13 décembre 2005 à 23:30:54 |
Re : Calculer des différences sous certaines conditions

nhervagault
|
C'est assez chaud à faire
car les bases de données ne sont pas faites pour faire ce genre de traitement
Pour faire cela il faudrait je pense utiliser les procédures stockées ou un programme qui est plus adaptée car les BDD ne sont pas faite pour des traitements entre lignes mais entre table ;-)
et de faire la liasons dessus num est le numero de la ligne il y a peut etre une fonction sql pour le faire
Ensuite
faire une requete du style
select A1, B2-A2,b.num, a.num from A, B where A.num = B.Num +1
Attention l'ordre des lignes est important aussi, je ne maitrise pas les focntions avancées de mysql désolé
Pour les procedures stockées je maitrise pas celle de mysql
|
|
mercredi 14 décembre 2005 à 10:32:14 |
Re : Calculer des différences sous certaines conditions

aieeeuuuuu
|
salut,
une solution un peu tordue mais qui pourrait bien marcher si elle est bien realisee, consisterait a creer une table temporaire contenant en plus des deux champs de ta table d'origine, un champ ID autoincrementé.
ensuite tu insere tes données classées par ordre de date dans ta table.
puis pour inserer dans ta table finale, tu fais la soustraction entre tes valeurs de la table temporaire ID n et de la table temporaire ID n-1.
une requete du genre
INSERT INTO MaTableFinale SELECT
|
|
mercredi 14 décembre 2005 à 10:34:47 |
Re : Calculer des différences sous certaines conditions

aieeeuuuuu
|
mouarfff ?!?
elle est passée ou la fin de mon post ???
bon je disais donc pour la requete :
INSERT INTO maTableFinale
SELECT T1.date, (T1.valeur - T2.valeur)
FROM tableTemporaire T1, tableTemporaire T2
WHERE T1.ID = T2.ID + 1
et ca ca devrait fonctionner.
|
|
jeudi 15 décembre 2005 à 00:58:09 |
Re : Calculer des différences sous certaines conditions

JoeyBlack
|
Merci, logiquement ca devrait marcher. (le temps que je trouve les commandes pour creer une table temporaire etc...)
Une dernière chose, bcp plus simple...
Si je veux créer une nouvelle table (date, valeur2) contenant les
valeurs de ma table (date,valeur) mais telle que valeur2 = valeur -
moyenne(valeur), la moyenne étant celle de toute la table...
Il y a un moyen de déclarer des variables temporaires dans une requete ?
Merci pour vos réponses en tous cas, ca m'aide beaucoup :)
|
|
jeudi 15 décembre 2005 à 08:51:33 |
Re : Calculer des différences sous certaines conditions

nhervagault
|
Salut
AVG --> moyenne je crois sinon (sum(*)/count(*)) as valeur2 Group by cléprimaire de la table
bon courage
|
|
jeudi 15 décembre 2005 à 09:57:28 |
Re : Calculer des différences sous certaines conditions

aieeeuuuuu
|
oui, c'est ca, pas besoin de varable temporaire dan sta requete :
tu fais juste
INSERT INTO NouvelleTable
SELECT date, valeur - (SELECT AVG(valeur) FROM MaTable) FROM MaTable
|
|
jeudi 15 décembre 2005 à 09:59:13 |
Re : Calculer des différences sous certaines conditions

aieeeuuuuu
|
quoique directement
INSERT INTO maNouvelleTable SELECT date, valeur - AVG(valeur) FROM MaTable
va peut etre fonctionner, mais je ne suis pas sur. ?!?
|
|
Cette discussion est classée dans : date, valeur, calculer, conditions, différences
Répondre à ce message
Sujets en rapport avec ce message
Connaitre la valeur dans un INSERT [ par PunkDude424 ]
Salut, je développe une application de gestion de rendez vous avec VB et SQL Server....j'ai une table rendezvous qui contient les informtions du rende
calculer l'age d'une personne [ par slante ]
HelloJ'ai creer une table en Oracle XE pour un arbre genealogique, j'ai besoin d'une query qui retourne l'age des personnes :vivantes, base sur la dat
SELECT [ par tjarvl ]
Salut j'ai une table ou je doit afficher la somme ,le maximum et la valeur correspondante au max d'une colonne; Je ne sais pas comment afficher la va
calcul de moyennes un peu complexe [ par cudenetf ]
Bonjour, je voudrais pouvoir calculer des moyennes de ventes d'un produit par jour et par tranche horaire sur un produit afin d'avoir un tableau de l
Ordonner selon une valeur [ par Isengard ]
Bonjour ! J'ai un petit problème assez énervant ! Je fais un système de réféncement d'évenement avec génération d'une frise chronologique qui fait ap
Sélectionner 2 fois le meme champ mais avec 2 conditions différentes [ par cispo ]
Bonjour, Comme je l'ai mis dans le titre, je cherche à effectuer une requete qui sélectionne 2 fois le meme champs mais avec 2 conditions différentes
Problème avec une requête [ par emmanuel9 ]
Bonjour à tous, J'ai une table Personne avec dans cette table une colonne "date de création" et ma requete ressemble à ca : "SELECT * FROM PERSONNE WH
Ajouter un an à une date (renouvelable chaque année) sous access [ par totolaterreur ]
Salut J'ai des requêtes SQL à faire sous access et dans les requêtes, je dois comparer des dates à une seule. Par exemple, je dois comparer 07/06/2006
XML et Requete [ par blueangel ]
blueangel12@yahoo.com 13/02/2006<b
DateTime SQL problem [ par toubal_99 ]
salutg un problem avec une requette SQL suivanteSoins.SQL.Clear;Soins.SQL.Add('SELECT * from Soins where Soins.Date_Heure= :Date_Heu
Livres en rapport
|
Derniers Blogs
TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko [FRAMEWORK 4] LES TASKS ET LE THREAD UI[FRAMEWORK 4] LES TASKS ET LE THREAD UI par fathi
Je viens de passer quelques temps au TechDay's et j'ai pu voir pas mal de session intéressante. Par contre une chose m'a un peu étonné lors de certaines de ces sessions qui abordaient les améliorations du framework .NET (donc le 4.5) : en gros, bea...
Cliquez pour lire la suite de l'article par fathi WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui m'ont suivi. Je profite de ce poste, pour faire le re...
Cliquez pour lire la suite de l'article par JeremyJeanson TECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PCTECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PC par ROMELARD Fabrice
Speakers: Thierry Rapatout, Antoine Petit et Xavier Trebbia Cette session entre dans le cadre des RDV Décideurs des TechDays 2012, elle est liée à la consumérisation de l'IT et la mise en place du "DeskTop as a Service" dans de plus en ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|