mirror of
https://github.com/qgis/QGIS.git
synced 2025-02-27 00:33:48 -05:00
[FEATURE]postgres provider: add support for timestamp types
This commit is contained in:
parent
7b0815b682
commit
f6e4e75cd6
@ -136,7 +136,3 @@ void QgsDateTimeEdit::resizeEvent( QResizeEvent * event )
|
||||
mNullLabel->setMinimumSize( rect().adjusted( 0, 0, -spinButtonWidth(), 0 ).size() );
|
||||
mNullLabel->setMaximumSize( rect().adjusted( 0, 0, -spinButtonWidth(), 0 ).size() );
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
@ -106,6 +106,18 @@ QVariant QgsDateTimeEditWrapper::value()
|
||||
if ( !mQDateTimeEdit )
|
||||
return QVariant( field().type() );
|
||||
|
||||
if ( field().type() == QVariant::DateTime )
|
||||
{
|
||||
if ( mQgsDateTimeEdit )
|
||||
{
|
||||
return mQgsDateTimeEdit->dateTime();
|
||||
}
|
||||
else
|
||||
{
|
||||
return mQDateTimeEdit->dateTime();
|
||||
}
|
||||
}
|
||||
|
||||
const QString fieldFormat = config( "field_format", QGSDATETIMEEDIT_DATEFORMAT ).toString();
|
||||
|
||||
if ( mQgsDateTimeEdit )
|
||||
@ -124,7 +136,7 @@ void QgsDateTimeEditWrapper::setValue( const QVariant &value )
|
||||
return;
|
||||
|
||||
const QString fieldFormat = config( "field_format", QGSDATETIMEEDIT_DATEFORMAT ).toString();
|
||||
const QDateTime date = QDateTime::fromString( value.toString(), fieldFormat );
|
||||
const QDateTime date = field().type() == QVariant::DateTime ? value.toDateTime() : QDateTime::fromString( value.toString(), fieldFormat );
|
||||
|
||||
if ( mQgsDateTimeEdit )
|
||||
{
|
||||
|
@ -878,6 +878,11 @@ bool QgsPostgresProvider::loadFields()
|
||||
fieldType = QVariant::Date;
|
||||
fieldSize = -1;
|
||||
}
|
||||
else if ( fieldTypeName == "timestamp" )
|
||||
{
|
||||
fieldType = QVariant::DateTime;
|
||||
fieldSize = -1;
|
||||
}
|
||||
else if ( fieldTypeName == "text" ||
|
||||
fieldTypeName == "bool" ||
|
||||
fieldTypeName == "geometry" ||
|
||||
|
Loading…
x
Reference in New Issue
Block a user