Salome HOME
update of plugin Verima
[modules/smesh.git] / src / Tools / Verima / Base / tableRatios.py
1 from PyQt4 import QtSql, QtCore
2 from tableDeBase import TableDeBase
3
4 class TableRatios (TableDeBase):
5       def __init__(self):
6           TableDeBase.__init__(self,"Ratios")
7           self.setField(('Maillage','Version','RatioMax','RatioMin','Quartile1','Mediane','Quartile3','Moyenne'))
8           self.setTypeField(('int','int','float','float','float','float','float','float'),('idMaillage','idVersion','Machine'))
9
10       def createSqlTable(self):
11           query=QtSql.QSqlQuery()
12
13           texteQuery ="create table Ratios(idMaillage int, idVersion int, "
14           texteQuery+="RatioMax float, RatioMin float, "
15           texteQuery+="Q1 float,"
16           texteQuery+="Mediane float,"
17           texteQuery+="Q3 float,"
18           texteQuery+="Moyenne float,"
19           texteQuery+="foreign key (idMaillage) references Maillages(id)," 
20           texteQuery+="foreign key (idVersion) references Versions(id)," 
21           texteQuery+="primary key (idMaillage,idVersion));"
22
23           print "Creation de TableRatios : " , query.exec_(texteQuery)
24
25       def getVal(self,idMaillage, idVersion,  Entite):
26           query=QtSql.QSqlQuery()
27           texteQuery ='select '+ str(Entite) + ' from Ratios where idMaillage='+str(idMaillage)
28           texteQuery+=' and  idVersion='+str(idVersion)
29           query.exec_(texteQuery)
30           nb=0
31           val=0                          # Valeur si l enregistrement n existe pas
32           while (query.next()) :
33               val=query.value(0).toFloat()[0]
34               nb=nb+1
35           if nb > 1 : print "Double valeur de Reference dans la table des mailles"
36           return val
37