1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkSQLiteQuery.h,v $
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/*----------------------------------------------------------------------------
Copyright (c) Sandia Corporation
See Copyright.txt or http://www.paraview.org/HTML/Copyright.html for details.
----------------------------------------------------------------------------*/
// .NAME vtkSQLiteQuery - vtkSQLQuery implementation for SQLite databases
//
// .SECTION Description
//
// This is an implementation of vtkSQLQuery for SQLite databases. See
// the documentation for vtkSQLQuery for information about what the
// methods do.
//
// .SECTION Bugs
//
// Sometimes Execute() will return false (meaning an error) but
// GetLastErrorText() winds up null. I am not certain why this is
// happening.
//
// .SECTION Thanks
// Thanks to Andrew Wilson from Sandia National Laboratories for implementing
// this class.
//
// .SECTION See Also
// vtkSQLDatabase vtkSQLQuery vtkSQLiteDatabase
#ifndef __vtkSQLiteQuery_h
#define __vtkSQLiteQuery_h
#include "vtkSQLQuery.h"
class vtkSQLiteDatabase;
class vtkVariant;
class vtkVariantArray;
struct vtk_sqlite3_stmt;
class VTK_IO_EXPORT vtkSQLiteQuery : public vtkSQLQuery
{
//BTX
friend class vtkSQLiteDatabase;
//ETX
public:
vtkTypeRevisionMacro(vtkSQLiteQuery, vtkSQLQuery);
void PrintSelf(ostream& os, vtkIndent indent);
static vtkSQLiteQuery *New();
// Description:
// Execute the query. This must be performed
// before any field name or data access functions
// are used.
bool Execute();
// Description:
// The number of fields in the query result.
int GetNumberOfFields();
// Description:
// Return the name of the specified query field.
const char* GetFieldName(int i);
// Description:
// Return the type of the field, using the constants defined in vtkType.h.
int GetFieldType(int i);
// Description:
// Advance row, return false if past end.
bool NextRow();
// Description:
// Return true if there is an error on the current query.
bool HasError();
// Description:
// Begin, abort (roll back), or commit a transaction.
bool BeginTransaction();
bool RollbackTransaction();
bool CommitTransaction();
//BTX
// Description:
// Return data in current row, field c
vtkVariant DataValue(vtkIdType c);
//ETX
// Description:
// Get the last error text from the query
const char* GetLastErrorText();
protected:
vtkSQLiteQuery();
~vtkSQLiteQuery();
vtkSetStringMacro(LastErrorText);
private:
vtkSQLiteQuery(const vtkSQLiteQuery &); // Not implemented.
void operator=(const vtkSQLiteQuery &); // Not implemented.
vtk_sqlite3_stmt *Statement;
bool InitialFetch;
int InitialFetchResult;
char *LastErrorText;
bool TransactionInProgress;
};
#endif // __vtkSQLiteQuery_h
|