You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdebindings/kjsembed/bindings/sql_imp.h

142 lines
3.9 KiB

/*
* Copyright (C) 2003, Ian Reinhart Geiser <geiseri@kde.org>
*
* 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 <tqsqlquery.h>
#include <tqsqldatabase.h>
namespace KJSEmbed {
namespace Bindings {
/**
* TTQObject Binding for TQSQLQuery.
*
* @author Ian Reinhart Geiser, geiseri@kde.org
* @version $Id$
*/
class SqlQuery : public BindingObject
{
Q_OBJECT
Q_PROPERTY( int size READ size)
Q_PROPERTY( int at READ at)
Q_PROPERTY( int numRowsAffected READ numRowsAffected )
Q_PROPERTY( bool select READ isSelect)
Q_PROPERTY( bool valid READ isValid)
Q_PROPERTY( bool active READ isActive)
Q_PROPERTY( TTQString lastError READ lastError)
Q_PROPERTY( TTQString lastQuery READ lastQuery)
public:
SqlQuery( TTQObject *parent=0, const char *name=0 );
SqlQuery( TTQObject *parent, const char *name, const TTQSqlQuery &q );
//SqlQuery( const SqlQuery &copy);
virtual ~SqlQuery();
TTQSqlQuery query(){ return m_query; }
void setQuery(const TTQSqlQuery &q) {m_query = TTQSqlQuery(q); }
int size () const;
bool isSelect () const;
bool isValid () const;
bool isActive () const;
int at () const;
int numRowsAffected () const;
TTQString lastError () const;
TTQString lastQuery () const;
public slots:
bool isNull ( int field );
bool exec ( const TTQString & m_query );
TTQVariant value ( int i );
bool seek ( int i, bool relative = FALSE );
bool next ();
bool prev ();
bool first ();
bool last ();
private:
TTQSqlQuery m_query;
};
/**
* TTQObject Binding for TQSQLDatabase.
*
* @author Ian Reinhart Geiser, geiseri@kde.org
* @version $Id$
*/
class SqlDatabase : public BindingObject
{
Q_OBJECT
Q_PROPERTY( TTQString databaseName READ databaseName WRITE setDatabaseName)
Q_PROPERTY( TTQString userName READ userName WRITE setUserName)
Q_PROPERTY( TTQString password READ password WRITE setPassword)
Q_PROPERTY( TTQString hostName READ hostName WRITE setHostName)
Q_PROPERTY( int port READ port WRITE setPort)
Q_PROPERTY( TTQString driverName READ driverName)
Q_PROPERTY( TTQString lastError READ lastError)
public:
SqlDatabase( TTQObject *parent=0, const char *name=0 );
virtual ~SqlDatabase();
public slots:
void setDatabaseName (const TTQString &name );
void setUserName (const TTQString &name );
void setPassword (const TTQString &password );
void setHostName (const TTQString &host );
void setPort ( int p );
TTQString databaseName () const;
TTQString userName () const;
TTQString password () const;
TTQString hostName () const;
int port () const;
TTQString driverName () const;
bool addDatabase ( const TTQString & type, const TTQString & connectionName = TTQSqlDatabase::defaultConnection );
TTQStringList drivers ();
bool open ();
bool open ( const TTQString &user, const TTQString &password );
void close ();
bool isOpen ();
bool isOpenError ();
TTQStringList tables ();
SqlQuery *exec( const TTQString &query );
TTQString lastError () const;
bool transaction ();
bool commit ();
bool rollback ();
private:
TTQString connectionName;
//TTQSqlDatabase *db;
};
} // namespace KJSEmbed::Bindings
} // namespace KJSEmbed
#endif // KJSEMBED_SQL_IMP_H