Mapping dei tipi di dati SQL Server

SQL Server e .NET Framework sono basati su sistemi di tipi diversi. La struttura Decimal .NET Framework dispone ad esempio di una scala massima di 28, mentre i tipi di dati decimali e numerici di SQL Server dispongono di una scala massima di 38. Per mantenere l'integrità dei dati nella lettura e scrittura dei dati, SqlDataReader espone metodi delle funzioni di accesso tipizzate specifici di SQL Server che restituiscono oggetti di System.Data.SqlTypes, nonché metodi delle funzioni di accesso che restituiscono tipi .NET Framework. Sia i tipi SQL Server che i tipi .NET Framework sono rappresentati anche dalle enumerazioni nelle classi DbType e SqlDbType, che è possibile usare quando si specificano tipi di dati SqlParameter.

La tabella seguente illustra il tipo di .NET Framework dedotto, le enumerazioni DbType e SqlDbType e i metodi della funzione di accesso per SqlDataReader.

Tipo di motore di database di SQL Server Tipo .NET Framework Enumerazione SqlDbType Funzione di accesso tipizzata SqlTypes SqlDataReader Enumerazione DbType Funzione di accesso tipizzata DbType SqlDataReader
bigint Int64 BigInt GetSqlInt64 Int64 GetInt64
binary Byte[] VarBinary GetSqlBinary Binary GetBytes
bit Booleano Bit GetSqlBoolean Boolean GetBoolean
char String

Char[]
Char GetSqlString AnsiStringFixedLength,

String
GetString

GetChars
date 1

(SQL Server 2008 e versioni successive)
Data/Ora Date 1 GetSqlDateTime Date 1 GetDateTime
datetime DataOra DateTime GetSqlDateTime DateTime GetDateTime
datetime2

(SQL Server 2008 e versioni successive)
Data/Ora DateTime2 None DateTime2 GetDateTime
datetimeoffset

(SQL Server 2008 e versioni successive)
DateTimeOffset DateTimeOffset Nessuno DateTimeOffset GetDateTimeOffset
decimal Decimale Decimal GetSqlDecimal Decimal GetDecimal
FILESTREAM attribute (varbinary(max)) Byte[] VarBinary GetSqlBytes Binary GetBytes
float Double Float GetSqlDouble Double GetDouble
image Byte[] Binary GetSqlBinary Binary GetBytes
int Int32 Int GetSqlInt32 Int32 GetInt32
money Decimale Money GetSqlMoney Decimal GetDecimal
nchar String

Char[]
NChar GetSqlString StringFixedLength GetString

GetChars
ntext String

Char[]
NText GetSqlString String GetString

GetChars
numeric Decimale Decimal GetSqlDecimal Decimal GetDecimal
nvarchar String

Char[]
NVarChar GetSqlString String GetString

GetChars
real Singola Real GetSqlSingle Single GetFloat
rowversion Byte[] Timestamp GetSqlBinary Binary GetBytes
smalldatetime Data/Ora DateTime GetSqlDateTime DateTime GetDateTime
smallint Int16 SmallInt GetSqlInt16 Int16 GetInt16
smallmoney Decimale SmallMoney GetSqlMoney Decimal GetDecimal
sql_variant Object 2 Variant GetSqlValue 2 Object GetValue 2
Testo String

Char[]
Text GetSqlString String GetString

GetChars
time

(SQL Server 2008 e versioni successive)
TimeSpan Time Nessuno Time GetTimeSpan
timestamp Byte[] Timestamp GetSqlBinary Binary GetBytes
tinyint Byte TinyInt GetSqlByte Byte GetByte
uniqueidentifier GUID UniqueIdentifier GetSqlGuid Guid GetGuid
varbinary Byte[] VarBinary GetSqlBinary Binary GetBytes
varchar String

Char[]
VarChar GetSqlString AnsiString, String GetString

GetChars
xml XML Xml GetSqlXml Xml Nessuno

1 Non è possibile impostare la proprietà DbType di un SqlParameter su SqlDbType.Date.
2 Usare una funzione di accesso tipizzata specifica se è noto il tipo sottostante di sql_variant.

Documentazione di SQL Server

Per altre informazioni sui tipi di dati di SQL Server, vedere Tipi di dati (Transact-SQL).

Vedi anche