]> gitweb.pimeys.fr Git - scripts-20-100.git/commitdiff
Nota bene SQL pour faire des calculs de trésoriers.
authorVincent Le Gallic <legallic@crans.org>
Mon, 30 Sep 2013 12:14:30 +0000 (14:14 +0200)
committerVincent Le Gallic <legallic@crans.org>
Mon, 30 Sep 2013 12:14:30 +0000 (14:14 +0200)
bde/tresorerie.sql [new file with mode: 0644]

diff --git a/bde/tresorerie.sql b/bde/tresorerie.sql
new file mode 100644 (file)
index 0000000..35a5106
--- /dev/null
@@ -0,0 +1,16 @@
+# écrit par 20-100 le 16/03/13 (ouais enfin surtout le 17)
+# Des requêtes SQL en vrac pour satisfaire Maylis, penser à porter ça sur la NK2015 avec une interface
+# pour les tréoriers
+
+# Avoir les soldes de tout le monde à une date particulière
+SELECT pseudo, numcbde, recu, emis, COALESCE(recu, 0)-COALESCE(emis, 0) AS solde FROM (SELECT adherents.pseudo, adherents.numcbde, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND destinataire=adherents.numcbde AND date<'2012-02-22') AS recu, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND emetteur=adherents.numcbde AND date<'2012-02-22') AS emis FROM adherents) AS calculs;
+
+# Avoir la somme de tous les soldes de tout le monde à cette date :
+SELECT sum(solde) FROM (SELECT pseudo, numcbde, recu, emis, COALESCE(recu, 0)-COALESCE(emis, 0) AS solde FROM (SELECT adherents.pseudo, adherents.numcbde, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND destinataire=adherents.numcbde AND date<'2012-02-22') AS recu, (SELECT sum(montant*quantite) FROM transactions WHERE valide AND emetteur=adherents.numcbde AND date<'2012-02-22') AS emis FROM adherents) AS calculs) AS soldes;
+# Oh ! ça fait 0 ! cool hein ?
+# Eh ben ça a pas été si trivial que ça… -_-
+
+
+# Le résumé des transactions du BDE, regroupé par type.
+SELECT sum(montant*quantite*(CASE WHEN emetteur=destinataire THEN 0 WHEN destinataire=0 THEN 1 ELSE -1 END)) AS total, remarque FROM transactions WHERE valide AND 0 in (emetteur, destinataire) AND date<='2013-02-19' AND date>='2012-02-22' GROUP BY remarque ORDER BY total;
+# Attention : penser à changer les *deux* 0 pour le faire sur quelqu'un d'autre.