X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIOSQLiteTreeHandler.cpp;h=596a92a17492e963abea3cabcd061ccb084549e4;hb=46fb4b43011a4043c7b5ef2e7bd57e1695cd6b7f;hp=8dcdd1795dcda95800944e9934bddd3f7c33200f;hpb=66f2d68a504d06b45b4047bd7a445c11889b9fc0;p=creaImageIO.git diff --git a/src2/creaImageIOSQLiteTreeHandler.cpp b/src2/creaImageIOSQLiteTreeHandler.cpp index 8dcdd17..596a92a 100644 --- a/src2/creaImageIOSQLiteTreeHandler.cpp +++ b/src2/creaImageIOSQLiteTreeHandler.cpp @@ -148,10 +148,8 @@ namespace creaImageIO tree::Node* parent=node->GetParent(); if (parent) { - parent->RemoveChildrenFromList(node); - int nC=GetNumberOfChildren(parent); - nC=nC-1; - if(nC>0) + int nC = parent->RemoveChildrenFromList(node); + if(nC>0 && parent->GetLevel()>0) { std::stringstream out; out <GetLevel()).GetName(); sql += " SET "; sql += key; - sql += "='"; + sql += " = '"; sql += value; - sql += "' WHERE ID="; + sql += "' WHERE ID = '"; sql += n->GetAttribute("ID"); + sql +="'"; // sql += " LIMIT 1"; UPDATEDB(sql); } @@ -897,6 +892,7 @@ namespace creaImageIO sql += " = '"; sql += searchVal; sql += "'"; + std::cout<GetLevel()).GetName() <GetChildrenList().begin(); - i != node->GetChildrenList().end(); - i++) - { - DBRecursiveRemoveNode((*i)); - } + + if(node->GetNumberOfChildren()!=0) + { + Node::ChildrenListType::iterator i; + for (i = node->GetChildrenList().begin(); + i != node->GetChildrenList().end(); + i++) + { + DBRecursiveRemoveNode((*i)); + } + } + else if(node->GetLevel()GetLevel()+1,node->GetAttribute("ID")); + } + } + + //===================================================================== + void SQLiteTreeHandler::DBRecursiveRemoveNode(int level, std::string parentId) + { + std::stringstream out; + std::stringstream result; + out<<"SELECT ID FROM "<GetLevel(); - + if(level0) { std::string query = "SELECT NumberOfChildren FROM "; @@ -1009,6 +1048,66 @@ namespace creaImageIO return nb; } + //===================================================================== + void SQLiteTreeHandler::GetTopLevelNodeId(const std::string& searchParam, const std::string& searchValue, std::string& parent_id) + { + int level=GetTree().GetNumberOfLevels()-1; + std::string sp=searchParam.c_str(); + std::string sv=searchValue.c_str(); + + while(level>1) + { + std::stringstream out; + std::stringstream results; + out<<"SELECT PARENT_ID FROM "<