summaryrefslogtreecommitdiffstats
path: root/kexi/migration
diff options
context:
space:
mode:
Diffstat (limited to 'kexi/migration')
-rw-r--r--kexi/migration/pqxx/pqxxmigrate.cpp65
1 files changed, 31 insertions, 34 deletions
diff --git a/kexi/migration/pqxx/pqxxmigrate.cpp b/kexi/migration/pqxx/pqxxmigrate.cpp
index 9460462c..119f2f65 100644
--- a/kexi/migration/pqxx/pqxxmigrate.cpp
+++ b/kexi/migration/pqxx/pqxxmigrate.cpp
@@ -523,43 +523,40 @@ tristate PqxxMigrate::drv_fetchRecordFromSQL(const TQString& sqlStatement,
bool PqxxMigrate::drv_copyTable(const TQString& srcTable, KexiDB::Connection *destConn,
KexiDB::TableSchema* dstTable)
{
- std::vector<std::string> R;
-
- pqxx::work T(*m_conn, "PqxxMigrate::drv_copyTable");
-
- pqxx::tablereader stream(T, (srcTable.latin1()));
-
- //Loop round each row, reading into a vector of strings
- const KexiDB::QueryColumnInfo::Vector fieldsExpanded( dstTable->query()->fieldsExpanded() );
- for (int n=0; (stream >> R); ++n)
+ if (query(TQString("SELECT * FROM ") + srcTable.latin1()))
{
- TQValueList<TQVariant> vals;
- std::vector<std::string>::const_iterator i, end( R.end() );
- int index = 0;
- for ( i = R.begin(); i != end; ++i, index++) {
- if (fieldsExpanded.at(index)->field->type()==KexiDB::Field::BLOB || fieldsExpanded.at(index)->field->type()==KexiDB::Field::LongText)
- {
- vals.append( KexiDB::pgsqlByteaToByteArray((*i).c_str(), (*i).size()) );
- }
- else if (fieldsExpanded.at(index)->field->type()==KexiDB::Field::Boolean )
- {
- vals.append(QString((*i).c_str()).lower() == "t" ? TQVariant(true, 1) : TQVariant(false, 1));
- }
- else
- {
- vals.append( KexiDB::cstringToVariant((*i).c_str(),
- fieldsExpanded.at(index)->field, (*i).size()) );
- }
+ pqxx::work T(*m_conn, "PqxxMigrate::drv_copyTable");
+
+ //Loop round each row, reading into a vector of strings
+ const KexiDB::QueryColumnInfo::Vector fieldsExpanded( dstTable->query()->fieldsExpanded() );
+ for (pqxx::result::const_iterator rowIt = m_res->begin(); rowIt != m_res->end(); ++rowIt)
+ {
+ TQValueList<TQVariant> vals;
+ int index = 0;
+ for (int i = 0; i < rowIt.size(); ++i, index++)
+ {
+ if (fieldsExpanded.at(index)->field->type()==KexiDB::Field::BLOB ||
+ fieldsExpanded.at(index)->field->type()==KexiDB::Field::LongText)
+ {
+ vals.append(KexiDB::pgsqlByteaToByteArray(rowIt.at(i).c_str(), rowIt.at(i).size()));
+ }
+ else if (fieldsExpanded.at(index)->field->type()==KexiDB::Field::Boolean)
+ {
+ vals.append(TQString(rowIt.at(i).c_str()).lower() == "t" ? TQVariant(true, 1) : TQVariant(false, 1));
+ }
+ else
+ {
+ vals.append(KexiDB::cstringToVariant(rowIt.at(i).c_str(), fieldsExpanded.at(index)->field, rowIt.at(i).size()));
+ }
+ }
+ if (!destConn->insertRecord(*dstTable, vals))
+ {
+ return false;
+ }
+ updateProgress();
}
- if (!destConn->insertRecord(*dstTable, vals))
- return false;
- updateProgress();
- R.clear();
+ m_res->clear();
}
-
- //This does not work in <libpqxx 2.2
- //stream.complete();
-
return true;
}