49 #ifndef vtkPostgreSQLDatabase_h
50 #define vtkPostgreSQLDatabase_h
52 #include "vtkIOPostgreSQLModule.h"
64 friend class vtkPostgreSQLQueryPrivate;
76 bool Open(
const char* password = 0 );
114 virtual void SetHostName(
const char* );
122 virtual void SetUser(
const char* );
129 virtual void SetPassword(
const char* );
135 virtual void SetDatabaseName(
const char* );
143 virtual void SetConnectOptions(
const char* );
151 virtual void SetServerPort(
int );
160 vtkGetMacro(ServerPort,
int);
195 bool CreateDatabase(
const char* dbName,
bool dropExisting =
false );
201 bool DropDatabase(
const char* dbName );
237 void UpdateDataTypeMap();
239 vtkSetStringMacro(DatabaseType);
240 vtkSetStringMacro(LastErrorText);
241 void NullTrailingWhitespace(
char* msg );
242 bool OpenInternal(
const char* connectionOptions );
265 #define vtkSetStringPlusMTimeMacro(className,name,timeStamp) \
266 inline void className::Set##name (const char* _arg) \
268 vtkDebugMacro(<< this->GetClassName() << " (" << this << "): setting " << #name " to " << (_arg?_arg:"(null)") ); \
269 if ( this->name == NULL && _arg == NULL) { return;} \
270 if ( this->name && _arg && (!strcmp(this->name,_arg))) { return;} \
271 delete [] this->name; \
274 size_t n = strlen(_arg) + 1; \
275 char *cp1 = new char[n]; \
276 const char *cp2 = (_arg); \
278 do { *cp1++ = *cp2++; } while ( --n ); \
285 this->timeStamp.Modified(); \
297 vtkDebugMacro(<< this->
GetClassName() <<
" (" <<
this <<
"): setting ServerPort to " << _arg );
307 #endif // vtkPostgreSQLDatabase_h
Wrapper around std::string to keep symbols short.
virtual VTK_NEWINSTANCE vtkSQLQuery * GetQueryInstance()=0
Return an empty query on this database.
virtual vtkStdString GetColumnSpecification(vtkSQLDatabaseSchema *schema, int tblHandle, int colHandle)
Return the SQL string with the syntax to create a column inside a "CREATE TABLE" SQL statement...
vtkTimeStamp ConnectionMTime
maintain a connection to a PostgreSQL database
virtual bool IsSupported(int vtkNotUsed(feature))
Return whether a feature is supported by the database.
void PrintSelf(ostream &os, vtkIndent indent)
Methods invoked by print to print information about the object including superclasses.
record modification and/or execution time
virtual bool Open(const char *password)=0
Open a new connection to the database.
virtual bool ParseURL(const char *url)=0
Subclasses should override this method to determine connection parameters given the URL...
internal details of a connection to a PostgreSQL database
void Modified()
Set this objects time to the current time.
virtual bool HasError()=0
Did the last operation generate an error.
a vtkAbstractArray subclass for strings
virtual vtkStdString GetURL()=0
Get the URL of the database.
represent an SQL database schema
virtual vtkStringArray * GetRecord(const char *table)=0
Get the list of fields for a particular table.
#define vtkSetStringPlusMTimeMacro(className, name, timeStamp)
virtual int GetServerPortMaxValue()
The port used for connecting to the database.
virtual int GetServerPortMinValue()
The port used for connecting to the database.
maintain a connection to an sql database
virtual void Close()=0
Close the connection to the database.
vtkPostgreSQLDatabasePrivate * Connection
a simple class to control print indentation
const char * GetClassName() const
Return the class name as a string.
vtkSQLQuery implementation for PostgreSQL databases
virtual bool IsOpen()=0
Return whether the database has an open connection.
vtkGetStringMacro(ExtensionsString)
Returns a string listing all available extensions.
virtual void Modified()
Update the modification time for this object.
virtual const char * GetLastErrorText()=0
Get the last error text from the database I'm using const so that people do NOT use the standard vtkG...
executes an sql query and retrieves results
static vtkObject * New()
Create an object with Debug turned off, modified time initialized to zero, and reference counting on...
virtual vtkStringArray * GetTables()=0
Get the list of tables from the database.
virtual void SetServerPort(int)
The port used for connecting to the database.