summaryrefslogtreecommitdiffstats
path: root/kjsembed/bindings/sql_imp.h
blob: 78e54756b7d83bc9b8b889ec97685d08b6d8f6f6 (plain)
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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
/*
 *  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 <qsqlquery.h>
#include <qsqldatabase.h>

namespace KJSEmbed {
namespace Bindings {

/**
 * QObject Binding for QSQLQuery.
 *
 * @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( QString lastError READ lastError)
	Q_PROPERTY( QString lastQuery READ lastQuery)

public:
	SqlQuery( QObject *parent=0, const char *name=0 );
	SqlQuery( QObject *parent, const char *name, const QSqlQuery &q );
	//SqlQuery( const SqlQuery &copy);
	virtual ~SqlQuery();

	QSqlQuery query(){ return m_query; }
	void setQuery(const QSqlQuery &q) {m_query = QSqlQuery(q); }

	int size () const;
	bool isSelect () const;
	bool isValid () const;
	bool isActive () const;
	int at () const;
	int numRowsAffected () const;
	QString lastError () const;
	QString lastQuery () const;

public slots:



	bool isNull ( int field );
	bool exec ( const QString & m_query );
	QVariant value ( int i );
	bool seek ( int i, bool relative = FALSE );
	bool next ();
	bool prev ();
	bool first ();
	bool last ();

private:
	QSqlQuery m_query;
};

/**
 * QObject Binding for QSQLDatabase.
 *
 * @author Ian Reinhart Geiser, geiseri@kde.org
 * @version $Id$
 */
class SqlDatabase : public BindingObject
{
    Q_OBJECT
    Q_PROPERTY( QString  databaseName READ databaseName WRITE setDatabaseName)
    Q_PROPERTY( QString  userName READ userName WRITE setUserName)
    Q_PROPERTY( QString  password READ password WRITE setPassword)
    Q_PROPERTY( QString  hostName READ hostName WRITE setHostName)
    Q_PROPERTY( int port READ port WRITE setPort)
    Q_PROPERTY( QString  driverName READ driverName)
    Q_PROPERTY( QString  lastError READ lastError)

public:
	SqlDatabase( QObject *parent=0, const char *name=0 );
	virtual ~SqlDatabase();


public slots:
	void setDatabaseName (const QString &name );
	void setUserName (const QString &name );
	void setPassword (const QString &password );
	void setHostName (const QString &host );
	void setPort ( int p );
	QString databaseName () const;
	QString userName () const;
	QString password () const;
	QString hostName () const;
	int port () const;
	QString driverName () const;
	
	bool addDatabase ( const QString & type, const QString & connectionName = QSqlDatabase::defaultConnection );
	QStringList drivers ();
	bool open ();
	bool open ( const QString &user, const QString &password );
	void close ();
	bool isOpen ();
	bool isOpenError ();
	QStringList tables ();
	SqlQuery *exec( const QString &query );
	QString  lastError () const;
	bool transaction ();
	bool commit ();
	bool rollback ();

private:
	QString connectionName;
	//QSqlDatabase *db;
};


} // namespace KJSEmbed::Bindings
} // namespace KJSEmbed

#endif // KJSEMBED_SQL_IMP_H