#ifndef ROOT_TTreeSQL
#define ROOT_TTreeSQL
#ifndef ROOT_TTree
#include "TTree.h"
#endif
#include <vector>
class TSQLServer;
class TSQLRow;
class TBasketSQL;
class TTreeSQL : public TTree {
protected:
Int_t fCurrentEntry;
TString fDB;
TString fInsertQuery;
TString fQuery;
TString fTable;
TSQLResult *fResult;
TSQLRow *fRow;
TSQLServer *fServer;
Bool_t fBranchChecked;
void CheckBasket(TBranch * tb);
Bool_t CheckBranch(TBranch * tb);
Bool_t CheckTable(const TString &table) const;
TString CreateBranches(TSQLResult * rs);
std::vector<Int_t> *GetColumnIndice(TBranch *branch);
void Init();
void ResetQuery();
TString ConvertTypeName(const TString& typeName );
virtual void CreateBranch(const TString& branchName,const TString &typeName);
Bool_t CreateTable(const TString& table);
virtual TBasket *CreateBasket(TBranch * br);
virtual TBranch *BranchImp(const char *branchname, const char *classname, TClass *ptrClass, void *addobj, Int_t bufsize, Int_t splitlevel);
virtual TBranch *BranchImp(const char *branchname, TClass *ptrClass, void *addobj, Int_t bufsize, Int_t splitlevel);
public:
TTreeSQL(TSQLServer * server, TString DB, const TString& table);
virtual Int_t Branch(TCollection *list, Int_t bufsize=32000, Int_t splitlevel=99, const char *name="");
virtual Int_t Branch(TList *list, Int_t bufsize=32000, Int_t splitlevel=99);
virtual Int_t Branch(const char *folder, Int_t bufsize=32000, Int_t splitlevel=99);
virtual TBranch *Bronch(const char *name, const char *classname, void *addobj, Int_t bufsize=32000, Int_t splitlevel=99);
virtual TBranch *BranchOld(const char *name, const char *classname, void *addobj, Int_t bufsize=32000, Int_t splitlevel=1);
#if !defined(__CINT__)
virtual TBranch *Branch(const char *name, const char *classname, void *addobj, Int_t bufsize=32000, Int_t splitlevel=99);
#endif
virtual TBranch *Branch(const char *name, void *address, const char *leaflist, Int_t bufsize);
virtual Int_t Fill();
virtual Int_t GetEntry(Long64_t entry=0, Int_t getall=0);
virtual Long64_t GetEntries() const;
virtual Long64_t GetEntries(const char *sel) { return TTree::GetEntries(sel); }
virtual Long64_t GetEntriesFast()const;
TString GetTableName(){ return fTable; }
virtual Long64_t LoadTree(Long64_t entry);
virtual Long64_t PrepEntry(Long64_t entry);
void Refresh();
ClassDef(TTreeSQL,1);
};
#endif