/* * Copyright (C) 2003, Ian Reinhart Geiser * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #ifndef KJSEMBED_SQL_IMP_H #define KJSEMBED_SQL_IMP_H #include "bindingobject.h" #include #include namespace KJSEmbed { namespace Bindings { /** * TQObject Binding for TQSQLQuery. * * @author Ian Reinhart Geiser, geiseri@kde.org * @version $Id$ */ class SqlQuery : public BindingObject { Q_OBJECT TQ_PROPERTY( int size READ size) TQ_PROPERTY( int at READ at) TQ_PROPERTY( int numRowsAffected READ numRowsAffected ) TQ_PROPERTY( bool select READ isSelect) TQ_PROPERTY( bool valid READ isValid) TQ_PROPERTY( bool active READ isActive) TQ_PROPERTY( TQString lastError READ lastError) TQ_PROPERTY( TQString lastQuery READ lastQuery) public: SqlQuery( TQObject *parent=0, const char *name=0 ); SqlQuery( TQObject *parent, const char *name, const TQSqlQuery &q ); //SqlQuery( const SqlQuery ©); virtual ~SqlQuery(); TQSqlQuery query(){ return m_query; } void setQuery(const TQSqlQuery &q) {m_query = TQSqlQuery(q); } int size () const; bool isSelect () const; bool isValid () const; bool isActive () const; int at () const; int numRowsAffected () const; TQString lastError () const; TQString lastQuery () const; public slots: bool isNull ( int field ); bool exec ( const TQString & m_query ); TQVariant value ( int i ); bool seek ( int i, bool relative = FALSE ); bool next (); bool prev (); bool first (); bool last (); private: TQSqlQuery m_query; }; /** * TQObject Binding for TQSQLDatabase. * * @author Ian Reinhart Geiser, geiseri@kde.org * @version $Id$ */ class SqlDatabase : public BindingObject { Q_OBJECT TQ_PROPERTY( TQString databaseName READ databaseName WRITE setDatabaseName) TQ_PROPERTY( TQString userName READ userName WRITE setUserName) TQ_PROPERTY( TQString password READ password WRITE setPassword) TQ_PROPERTY( TQString hostName READ hostName WRITE setHostName) TQ_PROPERTY( int port READ port WRITE setPort) TQ_PROPERTY( TQString driverName READ driverName) TQ_PROPERTY( TQString lastError READ lastError) public: SqlDatabase( TQObject *parent=0, const char *name=0 ); virtual ~SqlDatabase(); public slots: void setDatabaseName (const TQString &name ); void setUserName (const TQString &name ); void setPassword (const TQString &password ); void setHostName (const TQString &host ); void setPort ( int p ); TQString databaseName () const; TQString userName () const; TQString password () const; TQString hostName () const; int port () const; TQString driverName () const; bool addDatabase ( const TQString & type, const TQString & connectionName = TQSqlDatabase::defaultConnection ); TQStringList drivers (); bool open (); bool open ( const TQString &user, const TQString &password ); void close (); bool isOpen (); bool isOpenError (); TQStringList tables (); SqlQuery *exec( const TQString &query ); TQString lastError () const; bool transaction (); bool commit (); bool rollback (); private: TQString connectionName; //TQSqlDatabase *db; }; } // namespace KJSEmbed::Bindings } // namespace KJSEmbed #endif // KJSEMBED_SQL_IMP_H