Somme de valeur selon id inférieur
bibimul
Messages postés
30
Date d'inscription
Statut
Membre
Dernière intervention
-
yg_be Messages postés 23541 Date d'inscription Statut Contributeur Dernière intervention -
yg_be Messages postés 23541 Date d'inscription Statut Contributeur Dernière intervention -
Bonjour,
je travail dans une base de données SQlite.
J'ai créé actuellement le code suivant:
Si on imagine que je veux remplir la colonne "Coord_planni_E" en additionnant la colonne EST de l'ID inférieur et la colonne DEst de l'ID actuelle comment je peux faire ça?
Merci d'avance
je travail dans une base de données SQlite.
J'ai créé actuellement le code suivant:
import sqlite3 connexion = sqlite3.connect("test.sqlite") curseur=connexion.cursor() curseur.execute('''CREATE TABLE IF NOT EXISTS point(etat INTEGER, Est REAL, Nord REAL, DEst REAL, DNord REAL)''') donnees=[(0,2577817.4240,1227151.7845,0.0,0.0),(1,2577817.425,1227151.784,1.0,-0.5),(2,2577817.420,1227151.784,-4.0,-0.5),(3,2577817.4210,1227151.7840,-3.0,-0.5),(4,2577817.4210,1227151.7830,-3.0,-1.5),(5,2577817.4240,1227151.7830,0.0,-1.5),(6,2577817.4209,1227151.7823,-3.1,-2.2),(7,2577817.4210,1227151.7820,-3.0,-2.5),(8,2577817.4170,1227151.7830,-7.0,-1.5)] for donnee in donnees: curseur.execute('''INSERT INTO point(etat, Est, Nord, DEst, DNord) VALUES (?, ?, ?, ?, ?)''', donnee) connexion.commit() listColReal=('Coord_plani_E', 'Coord_plani_N') listColText=('Vecteur', 'WKT_Plani') for i in listColReal: curseur.execute('''ALTER TABLE point ADD COLUMN %s REAL''' % i) connexion.commit() for i in listColText: curseur.execute('''ALTER TABLE point ADD COLUMN %s TEXT''' % i) connexion.commit()
Si on imagine que je veux remplir la colonne "Coord_planni_E" en additionnant la colonne EST de l'ID inférieur et la colonne DEst de l'ID actuelle comment je peux faire ça?
Merci d'avance
A voir également:
- Somme de valeur selon id inférieur
- Formule somme excel colonne - Guide
- Somme si couleur - Guide
- Id telephone - Guide
- Inférieur ou égal clavier ✓ - Forum Word
- Https //id.sonyentertainmentnetwork.com/id/management/ ✓ - Forum PS4
3 réponses
yg_be
Messages postés
23541
Date d'inscription
Statut
Contributeur
Dernière intervention
Ambassadeur
1 584
bonjour, peux-tu expliciter ce que tu entends par "ID"?
ne peux-tu pas réaliser cela dans la boucle d'insertion?
il est, en général, déconseillé d'enregister des champs calculés.
dans quel contexte fais-tu ce travail?
ne peux-tu pas réaliser cela dans la boucle d'insertion?
il est, en général, déconseillé d'enregister des champs calculés.
dans quel contexte fais-tu ce travail?
bonjour,
alors pour l'ID j'entends ça comme le numéro de référence du point.
Au fur et à mesure que j'enregistre mes points dans mon Sqlite, un champ est créé avec un identifiant unique. Mais ça peut être aussi un autre champ.
Je fais ce travail pour créer un plugin sur QGIS qui me permette d'importer automatiquement un rapport après mesure. Donc je fais des mesures sur un chantier, j'ai un rapport avec des points et des écarts et j'aimerais maintenant importer ce rapport automatiquement.
Donc j'ai quelque calcul à faire en fonction d'étape.
Au final le but c'est d'obtenir des vecteur en chaque étape. Et pour ça j'aurais besoin de faire des calculs entre ces étapes.
alors pour l'ID j'entends ça comme le numéro de référence du point.
Au fur et à mesure que j'enregistre mes points dans mon Sqlite, un champ est créé avec un identifiant unique. Mais ça peut être aussi un autre champ.
Je fais ce travail pour créer un plugin sur QGIS qui me permette d'importer automatiquement un rapport après mesure. Donc je fais des mesures sur un chantier, j'ai un rapport avec des points et des écarts et j'aimerais maintenant importer ce rapport automatiquement.
Donc j'ai quelque calcul à faire en fonction d'étape.
Au final le but c'est d'obtenir des vecteur en chaque étape. Et pour ça j'aurais besoin de faire des calculs entre ces étapes.
Bin en l'occurence le champ qui sert d'ID c'est "etat"
bin alors, supposant que tu n'importes pas toutes tes données dans l'ordre et en une seule fois, tu peux utiliser cette requête pour obtenir le résultat attendu. il est inutile, je pense, d'enregistrer
Coord_planni_Edans une table.
select pa.etat, pa.Est, pa.Nord, pa.DEst, pa.DNord, pi.DEst as Coord_planni_E from point as pi, (select p1.etat, p1.Est, p1.Nord, p1.DEst, p1.DNord, max(p2.etat) as inferieur from point as p1, point as p2 where p2.etat < p1.etat group by p1.etat) as pa where pi.etat=inferieur
Bonjour,
j'avais compris : coord_planni_E = DEST + EST(n-1)
donc dans ta requete
j'ai celle là à proposer :
j'avais compris : coord_planni_E = DEST + EST(n-1)
donc dans ta requete
pa.DEst+pi.Est as Coord_planni_E.
j'ai celle là à proposer :
select a.etat, a.dest, b.etat, b.est, a.dest + b.est as result from point as a join point as b where b.etat = (select max(etat) from point where etat < a.etat)