SQL SERVER的字段类型说明

 更新时间:2008年04月30日 18:43:58   作者:  
以下为SQL SERVER 7.0以上版本的字段类型说明。SQL SERVER6.5的字段类型说明请参考
SQL SERVER提供的说明。 

bit:0或1的整型数字 
int:从-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型数字 
smallint:从-2^15(-32,768)到2^15(32,767)的整型数字 
tinyint:从0到255的整型数字 

decimal:从-10^38到10^38-1的定精度与有效位数的数字 
numeric:decimal的同义词 

money:从-2^63(-922,337,203,685,477.5808)到2^63-1(922,337,203,685,477.5807)的货币数据,最小货币单位千分之十 
smallmoney:从-214,748.3648到214,748.3647的货币数据,最小货币单位千分之十 

float:从-1.79E+308到1.79E+308可变精度的数字 
real:从-3.04E+38到3.04E+38可变精度的数字 

datetime:从1753年1月1日到9999年12日31的日期和时间数据,最小时间单位为百分之三秒或3.33毫秒 
smalldatetime:从1900年1月1日到2079年6月6日的日期和时间数据,最小时间单位为分钟 

timestamp:时间戳,一个数据库宽度的唯一数字 
uniqueidentifier:全球唯一标识符GUID 

char:定长非Unicode的字符型数据,最大长度为8000 
varchar:变长非Unicode的字符型数据,最大长度为8000 
text:变长非Unicode的字符型数据,最大长度为2^31-1(2G) 

nchar:定长Unicode的字符型数据,最大长度为8000 
nvarchar:变长Unicode的字符型数据,最大长度为8000 
ntext:变长Unicode的字符型数据,最大长度为2^31-1(2G) 

binary:定长二进制数据,最大长度为8000 
varbinary:变长二进制数据,最大长度为8000 
image:变长二进制数据,最大长度为2^31-1(2G) 

  简 介 

  MS的SQL Server主要是由五种常常用到的字段,字符型,文本型,数值型,逻辑型,和日期型!许多朋友苦于在一些BBS中ACCESS转换成SQL后字段类型不匹配而不知所措,下面我们就来介绍一些这五种数据类型各自的特性吧! 

  正 文 

  [1] 字符型数据Varchar,Char型 

  程序当中当大家需要存储比较短的字符串信息时我们就要用到字符型数据了,SQL中的字符型数据又有两种型!VARCHAR和CHAR型,正两种类型的数据差别是很细微的,但是却很重要! 

  比如当你像一个长度为40个字符的VARCHAR型字段中输入一个长度为4的字符串TOL8后你再取出的数据的时候,数据的长度为4个字符,而你把VARCHAR换成CHAR型,你取出的将会是40各字符长度的数据,字符串后会被附加多余的空格,比如TOL8只有4个字符那么从CHAR中取出的数据是TOL8加上36个空格!具体的程序设计中我个人还是推荐VARCHAR类型,因为从一些参考资料中我发现上面说VARCHAR型要比CHAR占用更少的硬盘很内存! 

  VARCHAR存储最长255个字符,超过这个长度就要用到我们下面将要讲到的文本型数据了。 

  [2] 文本型数据Text 

  文本型数据中你可以存储超过20亿个字符串,怎么样,这个够大了吧?但是也不是任何时候都是和使用文本型数据,因为他非常占空间,也非常消耗服务器,随处乱用后果不堪设想!因为即使你像一个文本型字段输入了一个空值他都会占用2K的空间!而当这时除了删除该数据没有别的办法收回空间! 

  [3] 数据型数据 Int,Tinying,Numeric 

  SQL支持多种不同的数据类型,让你可以存储整数,小数,和钱数! 

  INT(整型数据)表示范围是从-2,147,483,647 到 2,147,483,647 的整数 

  如果你的数值没有那么长,为了节省内存空间你可以使用SMALLINT它的表示范围是-32768到32768整数!二者的使用方法完全相同! 

  如果你还想再节省空间你可以选择使用TINYINT他只能存储0到255的整数注意TINYINT不能存储负数,一个TINYINT占用一个字节,而一个INT型数据占用4个字节! 

  [4] 数据型数据 Bit 

  网页复选框搜集信息存入数据库,是BIT型最常见的用法了!他只有两个值:0或1 

  [5] 数据型数据 Datetime,Samlldatetime 

  DATETIME的存储范围是从1753年1月1日第一毫秒到9999年12月31日最后一毫秒,如果你不需要覆盖面这么大的日期范围,可选使用SMALLDATETIME型它的存储范围是从1900年1月1日到2079年6月6日,但是只能精确到秒! 

  [6] 特殊型数据 Cursor 

  这里包括些2进制数据类型和一些其他不常用到的数据类型,我就不再多说了! 

相关文章

  • Lakehouse数据湖并发控制陷阱分析

    Lakehouse数据湖并发控制陷阱分析

    这篇文章主要为大家介绍了Lakehouse数据湖并发控制陷阱分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-03-03
  • Sybase数据库sa密码丢失后解决方法

    Sybase数据库sa密码丢失后解决方法

    sybase sa密码丢失的解决方法
    2008-04-04
  • Mssql,Access的sql经典SQL语句大全

    Mssql,Access的sql经典SQL语句大全

    常用不常用的一些sql语句,对数据库操作不是很熟练的朋友可以查询
    2012-03-03
  • clickhouse数据库删除数据的五种方式

    clickhouse数据库删除数据的五种方式

    clickhouse数据库清理数据的方式很多,每种方式都各有自己的优缺点,请根据实际需要采用适合自己的方式,本文将逐一给大家介绍,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-03-03
  • 90%程序员面试会遇到的索引优化问题

    90%程序员面试会遇到的索引优化问题

    不管是用C/C++/Java等代码编写的程序,还是SQL编写的数据库脚本,都存在一个持续优化的过程。也就是说,代码优化对于程序员来说,是一个永恒的话题。下面这篇文章主要给大家总结介绍了90%程序员在面试的时候会遇到的索引优化问题,需要的朋友可以参考下。
    2017-11-11
  • 什么是数据库索引 有哪些类型和特点

    什么是数据库索引 有哪些类型和特点

    这篇文章主要介绍了网站数据库的优化最为基础的优化措施就是建立数据库索引了,这里就介绍一下,什么是数据库索引?有哪些类型和特点
    2015-10-10
  • 带参数的sql和不带参数的sql存储过程区别

    带参数的sql和不带参数的sql存储过程区别

    来执行我们sql语句,看到很多分页存储过程都是直接拼凑sql语句然后用exec('')执行起来了,这个从效率和安全上面来说,都是不推荐的。
    2008-09-09
  • sql注入报错之注入原理实例解析

    sql注入报错之注入原理实例解析

    所谓报错注入,就是通过运行SQL查询语句回显查询结果,下面这篇文章主要给大家介绍了关于sql注入报错之注入原理的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • 干掉Navicat,这个数据库管理工具真香

    干掉Navicat,这个数据库管理工具真香

    这篇文章主要介绍了干掉Navicat,这个数据库管理工具真香,本文详细的介绍DataGrip的具体使用方法和实现,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • datagrip如何找到数据库和表

    datagrip如何找到数据库和表

    这篇文章主要介绍了datagrip入坑指南(如何找到数据库和表)的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-09-09

最新评论