SQL SERVER数据类型与C#数据类型的转换和相关.........
2011-03-22 14:21
477 查看
bigint
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。 Int64
int
从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。 Int32
smallint
从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。Int16
tinyint
从 0 到 255 的整型数据。存储大小为 1 字节。System.Byte
bit 1 或 0 的整数数据。Boolean
decimal
从 -10^38 +1 到 10^38 –1 的固定精度和小数位的数字数据。 Decimal
numeric
功能上等同于 decimal。 Decimal
money
货币数据值介于 -2^63 (-922,337,203,685,477.5808) 与 2^63 - 1 (+922,337,203,685,477.5807) 之间,精确到货币单位的千分之十。Decimal
smallmoney
货币数据值介于 -214,748.3648 与 +214,748.3647 之间,精确到货币单位的千分之十。Decimal
----------------------------------------------------------------------------------------------------------------
float
从 -1.79E + 308 到 1.79E + 308 的浮点精度数字。Double
real
从 -3.40E + 38 到 3.40E + 38 的浮点精度数字。 Single
datetime
从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确到百分之三秒(或 3.33 毫秒)。 DateTime
smalldatetime
从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间数据,精确到分钟。DateTime
----------------------------------------------------------------------------------------------------------------
char
固定长度的非 Unicode 字符数据,最大长度为 8,000 个字符。string
varchar
可变长度的非 Unicode 数据,最长为 8,000 个字符。String
text
可变长度的非 Unicode 数据,最大长度为 2^31 - 1 (2,147,483,647) 个字符。
string
varchar
可变长度的非 Unicode 数据,在 SQL2005+ 以后用来取代text。
string
Unicode
字符串 nchar 固定长度的 Unicode 数据,最大长度为 4,000 个字符。
string
nvarchar
可变长度 Unicode 数据,其最大长度为 4,000 字符。sysname 是系统提供用户定义的数据类型,在功能上等同于 nvarchar(128),用于引用数据库对象名。
string
ntext
可变长度 Unicode 数据,其最大长度为 2^30 - 1 (1,073,741,823) 个字符。
string
nvarchar
(max) 可变长度 Unicode 数据, 在 SQL 2005+ 以后用来取代ntext。
string
-----------------------------------------------------------------------------------------------------------
binary
固定长度的二进制数据,其最大长度为 8,000 个字节。 Byte[]
varbinary
可变长度的二进制数据,其最大长度为 8,000 个字节。 Byte[]
image
可变长度的二进制数据,其最大长度为 2^31 - 1 (2,147,483,647) 个字节。Byte[]
-----------------------------------------------------------------------------------------------------------
timestamp
数据库范围的唯一数字,每次更新行时也进行更新。DateTime
uniqueidentifier
全局唯一标识符 (GUID)。Guid
-----------------------------------------------------------------------------------------------------------
附:SQL Server 2005 常用数据类型
:
精确数字型:bigint(8字节)、int(4字节)、smallint(2字节)、tinyint(1字节)
近似数字型:float(取决于位数)、real(4字节)
日期时间型:datetime(1753年1月1日~9999年12月31日,可精确到3.33毫秒)、smalldatetime(1900年1月1日~2079年6月6日,可精确到1分钟)
字符串型:char(1字符1字节,长度不足时自动补空)、nchar(1字符占2字节,数据长度不足自动补空)、varchar(1字符占1字
节,(max)输入实际长度再加2字节)、nvarchar(1字符2字节,(max)输入实际长度再加2字节)、text(1字符占1字节/最大
2GB)、ntext(1字符占2字节/最大2GB)、binary(固定长度,长度不够自动补0x00)、varbinary(可变长度,输入数据的实
际长度)、image(可变长度,输入数据的实际长度)
其他类型:cursor、sql_variant、table、timestamp、uniqueidentifier、xml
【注意】
区别nchar和nvarchar字符串:一般较常使用varchar和nvarchar,而很少使用char和nchar,因为我们不需要字符补足空白而占用字节空间,相比于varchar,nvarchar更支持中文格式字符串而不保留空白。
#region 数据库类型转换为C#类型
public static string DataTypeToCType(string dataType)
{
string retType = "";
if (dataType.Equals("text") || dataType.Equals("varchar") || dataType.Equals("char") || dataType.Equals("nvarchar") || dataType.Equals("nchar"))
return "string";
if (dataType.Equals("int"))
return "int";
//if (dataType.Equals("bigint"))
// return "Int64";
if (dataType.Equals("smallint"))
return "Int16";
if (dataType.Equals("tinyint"))
return "byte";
if (dataType.Equals("bigint"))
return "long";
if (dataType.Equals("bit"))
return "bool";
if (dataType.Equals("money") || dataType.Equals("smallmoney") || dataType.Equals("numeric"))
return "decimal";
if (dataType.Equals("datetime") || dataType.Equals("smalldatetime") || dataType.Equals("timestamp"))
return "DateTime";
if (dataType.Equals("real"))
return "Single";
if (dataType.Equals("float"))
return "double";
if (dataType.Equals("image") || dataType.Equals("binary") || dataType.Equals("varbinary"))
return "byte[]";
if (dataType.Equals("uniqueidentifier"))
return "Guid";
return retType;
}
#endregion
从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。 Int64
int
从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。 Int32
smallint
从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。Int16
tinyint
从 0 到 255 的整型数据。存储大小为 1 字节。System.Byte
bit 1 或 0 的整数数据。Boolean
decimal
从 -10^38 +1 到 10^38 –1 的固定精度和小数位的数字数据。 Decimal
numeric
功能上等同于 decimal。 Decimal
money
货币数据值介于 -2^63 (-922,337,203,685,477.5808) 与 2^63 - 1 (+922,337,203,685,477.5807) 之间,精确到货币单位的千分之十。Decimal
smallmoney
货币数据值介于 -214,748.3648 与 +214,748.3647 之间,精确到货币单位的千分之十。Decimal
----------------------------------------------------------------------------------------------------------------
float
从 -1.79E + 308 到 1.79E + 308 的浮点精度数字。Double
real
从 -3.40E + 38 到 3.40E + 38 的浮点精度数字。 Single
datetime
从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确到百分之三秒(或 3.33 毫秒)。 DateTime
smalldatetime
从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间数据,精确到分钟。DateTime
----------------------------------------------------------------------------------------------------------------
char
固定长度的非 Unicode 字符数据,最大长度为 8,000 个字符。string
varchar
可变长度的非 Unicode 数据,最长为 8,000 个字符。String
text
可变长度的非 Unicode 数据,最大长度为 2^31 - 1 (2,147,483,647) 个字符。
string
varchar
可变长度的非 Unicode 数据,在 SQL2005+ 以后用来取代text。
string
Unicode
字符串 nchar 固定长度的 Unicode 数据,最大长度为 4,000 个字符。
string
nvarchar
可变长度 Unicode 数据,其最大长度为 4,000 字符。sysname 是系统提供用户定义的数据类型,在功能上等同于 nvarchar(128),用于引用数据库对象名。
string
ntext
可变长度 Unicode 数据,其最大长度为 2^30 - 1 (1,073,741,823) 个字符。
string
nvarchar
(max) 可变长度 Unicode 数据, 在 SQL 2005+ 以后用来取代ntext。
string
-----------------------------------------------------------------------------------------------------------
binary
固定长度的二进制数据,其最大长度为 8,000 个字节。 Byte[]
varbinary
可变长度的二进制数据,其最大长度为 8,000 个字节。 Byte[]
image
可变长度的二进制数据,其最大长度为 2^31 - 1 (2,147,483,647) 个字节。Byte[]
-----------------------------------------------------------------------------------------------------------
timestamp
数据库范围的唯一数字,每次更新行时也进行更新。DateTime
uniqueidentifier
全局唯一标识符 (GUID)。Guid
-----------------------------------------------------------------------------------------------------------
附:SQL Server 2005 常用数据类型
:
精确数字型:bigint(8字节)、int(4字节)、smallint(2字节)、tinyint(1字节)
近似数字型:float(取决于位数)、real(4字节)
日期时间型:datetime(1753年1月1日~9999年12月31日,可精确到3.33毫秒)、smalldatetime(1900年1月1日~2079年6月6日,可精确到1分钟)
字符串型:char(1字符1字节,长度不足时自动补空)、nchar(1字符占2字节,数据长度不足自动补空)、varchar(1字符占1字
节,(max)输入实际长度再加2字节)、nvarchar(1字符2字节,(max)输入实际长度再加2字节)、text(1字符占1字节/最大
2GB)、ntext(1字符占2字节/最大2GB)、binary(固定长度,长度不够自动补0x00)、varbinary(可变长度,输入数据的实
际长度)、image(可变长度,输入数据的实际长度)
其他类型:cursor、sql_variant、table、timestamp、uniqueidentifier、xml
【注意】
区别nchar和nvarchar字符串:一般较常使用varchar和nvarchar,而很少使用char和nchar,因为我们不需要字符补足空白而占用字节空间,相比于varchar,nvarchar更支持中文格式字符串而不保留空白。
#region 数据库类型转换为C#类型
public static string DataTypeToCType(string dataType)
{
string retType = "";
if (dataType.Equals("text") || dataType.Equals("varchar") || dataType.Equals("char") || dataType.Equals("nvarchar") || dataType.Equals("nchar"))
return "string";
if (dataType.Equals("int"))
return "int";
//if (dataType.Equals("bigint"))
// return "Int64";
if (dataType.Equals("smallint"))
return "Int16";
if (dataType.Equals("tinyint"))
return "byte";
if (dataType.Equals("bigint"))
return "long";
if (dataType.Equals("bit"))
return "bool";
if (dataType.Equals("money") || dataType.Equals("smallmoney") || dataType.Equals("numeric"))
return "decimal";
if (dataType.Equals("datetime") || dataType.Equals("smalldatetime") || dataType.Equals("timestamp"))
return "DateTime";
if (dataType.Equals("real"))
return "Single";
if (dataType.Equals("float"))
return "double";
if (dataType.Equals("image") || dataType.Equals("binary") || dataType.Equals("varbinary"))
return "byte[]";
if (dataType.Equals("uniqueidentifier"))
return "Guid";
return retType;
}
#endregion
相关文章推荐
- C#调用C++的DLL搜集整理的所有数据类型转换方式 (转)
- SQL Server 与ORACLE数据类型转换对应关系
- C#之数据类型转换
- C#根据输入框的字符判断可以转换为那些数据类型
- 处理数据类型转换,数制转换、编码转换相关的类
- C# 基本数据类型和Byte [] 相互转换
- C# 的数据类型转换 c#字符串转换格式 c#日期数字字符串整形格式转换
- C#操作技巧的数据类型之间的转换
- C#:数据类型转换
- C#调用C++ DLL数据类型转换
- C#操作SQL Server中的Image类型数据
- C#调用C++的DLL 所有数据类型转换方式
- SQL中转换数据类型的 Cast和Convert的用法和区别 SQL Server 函数
- C#中SQL SERVER 2008字符数据类型使用心得
- 高效掌握C#第一回---C#中的基本数据类型及其相互转换
- C#语言基础之数据类型的转换
- C#与C++的混合编程 之三 C++与C#的数据传递与类型转换
- C#中数据类型转换-隐式转换
- C#中数据类型的安全转换(is,as)
- SQL SERVER数据类型与C#数据类型对照表