QSqlRecordInfo QMYSQLDriver::recordInfo( const QSqlQuery& query ) const { QSqlRecordInfo info; if ( !isOpen() ) return info; if ( query.isActive() && query.isSelect() && query.driver() == this ) { QMYSQLResult* result = (QMYSQLResult*)query.result(); QMYSQLResultPrivate* p = result->d; if ( !mysql_errno( p->mysql ) ) { for ( ;; ) { MYSQL_FIELD* field = mysql_fetch_field( p->result ); if ( field ) { info.append ( QSqlFieldInfo( QString( field->name ), qDecodeMYSQLType( (int)field->type, field->flags ), IS_NOT_NULL( field->flags ), (int)field->length, (int)field->decimals, QVariant(), (int)field->type ) ); } else break; } } mysql_field_seek( p->result, 0 ); } return info; }
// called on first fetch void QSQLiteResultPrivate::init(const char **cnames, int numCols, QtSqlCachedResult::RowCache **row) { if (!cnames) return; rInf.clear(); if (numCols <= 0) return; for (int i = 0; i < numCols; ++i) { const char* lastDot = strrchr(cnames[i], '.'); const char* fieldName = lastDot ? lastDot + 1 : cnames[i]; rInf.append(QSqlFieldInfo(fieldName, nameToType(cnames[i+numCols]))); } // skip the first fetch if (row && !*row) { *row = new QtSqlCachedResult::RowCache(numCols); skipRow = *row; } }
QSqlRecordInfo QMYSQLDriver::recordInfo( const QString& tablename ) const { QSqlRecordInfo info; if ( !isOpen() ) return info; MYSQL_RES* r = mysql_list_fields( d->mysql, tablename.local8Bit().data(), 0); if ( !r ) { return info; } MYSQL_FIELD* field; while ( (field = mysql_fetch_field( r ))) { info.append ( QSqlFieldInfo( QString( field->name ), qDecodeMYSQLType( (int)field->type, field->flags ), IS_NOT_NULL( field->flags ), (int)field->length, (int)field->decimals, QString( field->def ), (int)field->type ) ); } mysql_free_result( r ); return info; }
QSqlRecordInfo SqliteDriver::recordInfo(const QString &tablename) const { QSqlRecordInfo info; if (!isOpen() || !dataBase_) return info; QDomDocument doc(tablename); QDomElement docElem; QString stream = db_->managerModules()->contentCached(tablename + ".mtd"); if (!FLUtil::domDocumentSetContent(doc, stream)) { #ifdef FL_DEBUG qWarning("FLManager : " + QApplication::tr("Error al cargar los metadatos para la tabla %1").arg(tablename)); #endif return recordInfo2(tablename); } docElem = doc.documentElement(); FLTableMetaData *mtd = db_->manager()->metadata(&docElem, true); if (!mtd) return recordInfo2(tablename); FLTableMetaData::FLFieldMetaDataList *fl = mtd->fieldList(); if (!fl) { delete mtd; return recordInfo2(tablename); } if (fl->isEmpty()) { delete mtd; return recordInfo2(tablename); } QStringList fieldsNames = QStringList::split(",", mtd->fieldsNames()); for (QStringList::Iterator it = fieldsNames.begin(); it != fieldsNames.end(); ++it) { FLFieldMetaData *field = mtd->field((*it)); info.append(QSqlFieldInfo(field->name(), FLFieldMetaData::flDecodeType(field->type()))); } delete mtd; return info; }
void QSqlCursor::remove( int pos ) { d->editBuffer.remove( pos ); d->infoBuffer[ pos ] = QSqlFieldInfo(); QSqlRecord::remove( pos ); }
/*! \internal cursors should be filled with QSqlFieldInfos... */ void QSqlCursor::insert( int pos, const QSqlField& field ) { insert( pos, QSqlFieldInfo( field ) ); }
/*! \internal cursors should be filled with QSqlFieldInfos... */ void QSqlCursor::append( const QSqlField& field ) { append( QSqlFieldInfo( field ) ); }