Nuevas características de fecha y hora con versiones de SQL Server anteriores (OLE DB)
Se aplica a:SQL ServerAzure SQL DatabaseAzure SQL Managed InstanceAzure Synapse AnalyticsAnalytics Platform System (PDW)
En este tema se describe el comportamiento esperado cuando una aplicación cliente que usa características mejoradas de fecha y hora se comunica con una versión de SQL Server anterior a SQL Server 2008 (10.0.x) y cuando un cliente compilado con una versión de SQL Server Native Client anterior a SQL Server 2008 (10.0.x) envía comandos a un servidor que admite características mejoradas de fecha y hora.
Comportamiento del cliente de nivel inferior
Las aplicaciones cliente que usan una versión de SQL Server Native Client anterior a SQL Server 2008 (10.0.x) ven los nuevos tipos de fecha y hora como columnas nvarchar . El contenido de las columnas son representaciones de literales. Para obtener más información, vea la sección "Formatos de datos: cadenas y literales" de compatibilidad de tipos de datos para las mejoras de fecha y hora de OLE DB. El tamaño de columna es la longitud máxima del literal para la precisión especificada para la columna.
Las API de catálogo devolverán metadatos coherentes con el código de tipo de datos de nivel descendente devuelto al cliente (por ejemplo, nvarchar) y la representación de nivel descendente asociada (por ejemplo, el formato literal adecuado). Sin embargo, el nombre del tipo de datos devuelto será el nombre de tipo real de SQL Server 2008 (10.0.x).
Cuando una aplicación cliente de nivel anterior se ejecuta en un servidor de SQL Server 2008 (10.0.x) (o posterior) en el que se han realizado cambios de esquema en los tipos de fecha y hora, el comportamiento esperado es el siguiente:
Tipo de cliente OLE DB | Tipo de SQL Server 2005 | Tipo de SQL Server 2008 (o posterior) | Conversión del resultado (servidor a cliente) | Conversión de parámetros (cliente a servidor) |
---|---|---|---|---|
DBTYPE_DBDATE | Datetime | Date | Aceptar | Aceptar |
DBTYPE_DBTIMESTAMP | Los campos de hora se establecen en cero. | IRowsetChange producirá un error debido al truncamiento de cadenas si el campo de hora es distinto de cero. | ||
DBTYPE_DBTIME | Time(0) | Aceptar | Aceptar | |
DBTYPE_DBTIMESTAMP | Los campos de fecha se establecen en la fecha actual. | IRowsetChange producirá un error debido al truncamiento de cadenas si las fracciones de segundos no son cero. Se omite la fecha. |
||
DBTYPE_DBTIME | Time(7) | Error: literal de hora no válido. | Aceptar | |
DBTYPE_DBTIMESTAMP | Error: literal de hora no válido. | Aceptar | ||
DBTYPE_DBTIMESTAMP | Datetime2(3) | Aceptar | Aceptar | |
DBTYPE_DBTIMESTAMP | Datetime2(7) | Aceptar | Aceptar | |
DBTYPE_DBDATE | Smalldatetime | Date | Aceptar | Aceptar |
DBTYPE_DBTIMESTAMP | Los campos de hora se establecen en cero. | IRowsetChange producirá un error debido al truncamiento de cadenas si el campo de tiempo no es cero. | ||
DBTYPE_DBTIME | Time(0) | Aceptar | Aceptar | |
DBTYPE_DBTIMESTAMP | Los campos de fecha se establecen en la fecha actual. | IRowsetChange producirá un error debido al truncamiento de cadenas si las fracciones de segundos no son cero. Se omite la fecha. |
||
DBTYPE_DBTIMESTAMP | Datetime2(0) | Aceptar | Aceptar |
Ok significa que si funcionaba con SQL Server 2005 (9.x), debería seguir trabajando con SQL Server 2008 (10.0.x) (o posterior).
Solo se han considerado los siguientes cambios de esquema:
Usar un nuevo tipo donde de forma lógica una aplicación requiere un único valor de fecha u hora. Sin embargo, la aplicación se vio obligada a usar datetime o smalldatetime porque los tipos de fecha y hora independientes no estaban disponibles.
Usar un nuevo tipo para obtener más precisión o exactitud en fracciones de segundo.
Cambiar a datetime2 porque es el tipo de datos preferido para la fecha y hora.
Las aplicaciones que usan metadatos de servidor obtenidos a través de ICommandWithParameters::GetParameterInfo o conjuntos de filas de esquema para establecer información de tipo de parámetro a través de ICommandWithParameters::SetParameterInfo producirán un error durante las conversiones de cliente donde la representación de cadena de un tipo de origen es mayor que la representación de cadena del tipo de destino. Por ejemplo, si un enlace de cliente usa DBTYPE_DBTIMESTAMP y la columna del servidor es fecha, SQL Server Native Client convertirá el valor en "aaaa-dd-mm hh:mm:ss.fff", pero los metadatos del servidor se devolverán como nvarchar(10). El desbordamiento resultante provoca DBSTATUS_E_CANTCONVERTVALUE. Surgen problemas similares con las conversiones de datos por IRowsetChange, ya que los metadatos del conjunto de filas se establecen a partir de los metadatos del conjunto de resultados.
Parámetros y metadatos de conjuntos de filas
En esta sección se describen los metadatos de parámetros, columnas de resultados y conjuntos de filas de esquema para los clientes que se compilan con una versión de SQL Server Native Client anterior a SQL Server 2008 (10.0.x).
ICommandWithParameters::GetParameterInfo
La estructura DBPARAMINFO devuelve la siguiente información a través del parámetro prgParamInfo :
Tipo de parámetro | wType | ulParamSize | bPrecision | bScale |
---|---|---|---|---|
date | DBTYPE_WSTR | 10 | ~0 | ~0 |
time | DBTYPE_WSTR | 8, 10..16 | ~0 | ~0 |
smalldatetime | DBTYPE_DBTIMESTAMP | 16 | 16 | 0 |
datetime | DBTYPE_DBTIMESTAMP | 16 | 23 | 3 |
datetime2 | DBTYPE_WSTR | 19,21..27 | ~0 | ~0 |
datetimeoffset | DBTYPE_WSTR | 26,28..34 | ~0 | ~0 |
Observe que algunos de estos intervalos de valores no son continuos; por ejemplo, en el intervalo 8,10..16 falta el 9. Esto se debe a la adición de un separador decimal cuando la precisión fraccionaria es mayor que cero.
IColumnsRowset::GetColumnsRowset
Se devuelven las siguientes columnas:
Tipo de columna | DBCOLUMN_TYPE | DBCOLUMN_COLUMNSIZE | DBCOLUMN_PRECISION | DBCOLUMN_SCALE, DBCOLUMN_DATETIMEPRECISION |
---|---|---|---|---|
date | DBTYPE_WSTR | 10 | NULL | NULL |
time | DBTYPE_WSTR | 8, 10..16 | NULL | NULL |
smalldatetime | DBTYPE_DBTIMESTAMP | 16 | 16 | 0 |
datetime | DBTYPE_DBTIMESTAMP | 16 | 23 | 3 |
datetime2 | DBTYPE_WSTR | 19,21..27 | NULL | NULL |
datetimeoffset | DBTYPE_WSTR | 26,28..34 | NULL | NULL |
ColumnsInfo::GetColumnInfo
La estructura DBCOLUMNINFO devuelve la siguiente información:
Tipo de parámetro | wType | ulColumnSize | bPrecision | bScale |
---|---|---|---|---|
date | DBTYPE_WSTR | 10 | ~0 | ~0 |
time(1..7) | DBTYPE_WSTR | 8, 10..16 | ~0 | ~0 |
smalldatetime | DBTYPE_DBTIMESTAMP | 16 | 16 | 0 |
datetime | DBTYPE_DBTIMESTAMP | 16 | 23 | 3 |
datetime2 | DBTYPE_WSTR | 19,21..27 | ~0 | ~0 |
datetimeoffset | DBTYPE_WSTR | 26,28..34 | ~0 | ~0 |
Conjuntos de filas de esquema
En esta sección se describen los metadatos para los parámetros, columnas de resultados y conjuntos de filas de esquema de los nuevos tipos de datos. Esta información es útil es que tiene un proveedor de clientes desarrollado con herramientas anteriores a SQL Server 2008 (10.0.x) SQL Server Native Client.
Conjunto de filas COLUMNS
Para los tipos de fecha y hora se devuelven los siguientes valores de columna:
Tipo de columna | DATA_TYPE | CHARACTER_MAXIMUM_LENGTH | CHARACTER_OCTET_LENGTH | DATETIME_PRECISION |
---|---|---|---|---|
date | DBTYPE_WSTR | 10 | 20 | NULL |
time | DBTYPE_WSTR | 8, 10..16 | 16,20..32 | NULL |
smalldatetime | DBTYPE_DBTIMESTAMP | NULL | NULL | 0 |
datetime | DBTYPE_DBTIMESTAMP | NULL | NULL | 3 |
datetime2 | DBTYPE_WSTR | 19,21..27 | 38,42..54 | NULL |
datetimeoffset | DBTYPE_WSTR | 26,28..34 | 52, 56..68 | NULL |
Conjunto de filas PROCEDURE_PARAMETERS
Para los tipos de fecha y hora se devuelven los siguientes valores de columna:
Tipo de columna | DATA_TYPE | CHARACTER_MAXIMUM_LENGTH | CHARACTER_OCTET_LENGTH | TYPE_NAME LOCAL_TYPE_NAME |
---|---|---|---|---|
date | DBTYPE_WSTR | 10 | 20 | date |
time | DBTYPE_WSTR | 8, 10..16 | 16,20..32 | time |
smalldatetime | DBTYPE_DBTIMESTAMP | NULL | NULL | smalldatetime |
datetime | DBTYPE_DBTIMESTAMP | NULL | NULL | datetime |
datetime2 | DBTYPE_WSTR | 19,21..27 | 38,42..54 | datetime2 |
datetimeoffset | DBTYPE_WSTR | 26,28..34 | 52, 56..68 | datetimeoffset |
Conjunto de filas PROVIDER_TYPES
Para los tipos de fecha y hora se devuelven las siguientes filas:
Tipo -> Columna |
date | time | smalldatetime | datetime | datetime2 | datetimeoffset |
---|---|---|---|---|---|---|
TYPE_NAME | date | time | smalldatetime | datetime | datetime2 | datetimeoffset |
DATA_TYPE | DBTYPE_WSTR | DBTYPE_WSTR | DBTYPE_DBTIMESTAMP | DBTYPE_DBTIMESTAMP | DBTYPE_WSTR | DBTYPE_WSTR |
COLUMN_SIZE | 10 | 16 | 16 | 23 | 27 | 34 |
LITERAL_PREFIX | ' | ' | ' | ' | ' | ' |
LITERAL_SUFFIX | ' | ' | ' | ' | ' | ' |
CREATE_PARAMS | NULL | NULL | NULL | NULL | NULL | NULL |
IS_NULLABLE | VARIANT_TRUE | VARIANT_TRUE | VARIANT_TRUE | VARIANT_TRUE | VARIANT_TRUE | VARIANT_TRUE |
CASE_SENSITIVE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE |
SEARCHABLE | DB_SEARCHABLE | DB_SEARCHABLE | DB_SEARCHABLE | DB_SEARCHABLE | DB_SEARCHABLE | DB_SEARCHABLE |
UNSIGNED_ATTRIBUTE | NULL | NULL | NULL | NULL | NULL | NULL |
FIXED_PREC_SCALE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE |
AUTO_UNIQUE_VALUE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE |
LOCAL_TYPE_NAME | date | time | smalldatetime | datetime | datetime2 | datetimeoffset |
MINIMUM_SCALE | NULL | NULL | NULL | NULL | NULL | NULL |
MAXIMUM_SCALE | NULL | NULL | NULL | NULL | NULL | NULL |
GUID | NULL | NULL | NULL | NULL | NULL | NULL |
TYPELIB | NULL | NULL | NULL | NULL | NULL | NULL |
VERSION | NULL | NULL | NULL | NULL | NULL | NULL |
IS_LONG | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE |
BEST_MATCH | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_TRUE | VARIANT_FALSE | VARIANT_FALSE |
IS_FIXEDLENGTH | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE | VARIANT_FALSE |
Comportamiento de un servidor de nivel inferior
Cuando se conecta a un servidor de una versión anterior a SQL Server 2008 (10.0.x), cualquier intento de usar los nuevos nombres de tipo de servidor (por ejemplo, con ICommandWithParameters::SetParameterInfo o ITableDefinition::CreateTable) dará como resultado DB_E_BADTYPENAME.
Si los nuevos tipos se enlazan en parámetros o resultados sin usar un nombre de tipo y el nuevo tipo se usa para especificar implícitamente el tipo de servidor, o no hay ninguna conversión válida del tipo de servidor al tipo de cliente, se devuelve DB_E_ERRORSOCCURRED, y DBBINDSTATUS_UNSUPPORTED_CONVERSION se establece como estado de enlace para el descriptor de acceso que se usó en Execute.
Si hay una conversión de cliente compatible del tipo de búfer al tipo de servidor para la versión del servidor en la conexión, pueden usarse todos los tipos de búfer del cliente. En este contexto, el tipo de servidor significa el tipo especificado por ICommandWithParameters::SetParameterInfo o implícito en el tipo de búfer si no se ha llamado a ICommandWithParameters::SetParameterInfo. Esto significa que DBTYPE_DBTIME2 y DBTYPE_DBTIMESTAMPOFFSET pueden usarse con servidores de nivel inferior, o cuando DataTypeCompatibility=80, si la conversión del cliente a un tipo de servidor compatible se realiza correctamente. Es evidente que si el tipo de servidor es incorrecto, el servidor todavía podría notificar un error si no puede realizar una conversión implícita al tipo de servidor real.
Comportamiento de SSPROP_INIT_DATATYPECOMPATIBILITY
Cuando SSPROP_INIT_DATATYPECOMPATIBILITY se establece en SSPROPVAL_DATATYPECOMPATIBILITY_SQL2000, los nuevos tipos de fecha y hora y los metadatos asociados aparecen a los clientes a medida que aparecen para los clientes de nivel inferior, como se describe en Cambios de copia masiva para tipos mejorados de fecha y hora (OLE DB y ODBC).
Comparaciones en IRowsetFind
Se permiten todos los operadores de comparación para los nuevos tipos de fecha y hora, debido a que aparecen como tipos de cadena en lugar de tipos de fecha y hora.