一、 整数数据类型

1、bit

bit数据类型是整型,其值只能是0、1或空值。这种数据类型用于存储只有两种可能值的数据,如Yes 或No、True 或False 、On 或Off.
注意:很省空间的一种数据类型,如果能够满足需求应该尽量多用。每个TINYINT类型的数据占用1个字节的存储空间。

  • bit值保存为1、0或NULL 的整数数据类型。1代表true,0代表false。
  • 在插入、修改 bit 数据时,使用 0 或 1。
    SQL Server将字符串值“TRUE”(字符串不分大小写,或者数字字符'1')转换为1,将“FALSE”(字符串不分大小写,或者数字字符'0')转换为0。将任何非零值转换为1。
  • 在c# 中读取数据库数据时,可以直接用bool型读取该字段,会直接转换为true/false。

2、tinyint

tinyint数据类型存储从0 到255 之间的所有正整数。每个tinyint类型的数据占用1个字节的存储空间。

3、smallint

smallint数据类型存储从-2的15次方( -32768) 到2的15次方-1( 32767 )之间的所有正负整数。
每个smallint类型的数据占用2个字节的存储空间,其中1 位表示整数值的正负号,其它15 位表示整数值的长度和大小。

4、int (integer)

int (或 integer)数据类型存储从-2的31次方 (-2147483648) 到2的31次方-1 (2147483647) 之间的所有正负整数。
每个INT 类型的数据按4个字节存储,其中1 位表示整数值的正负号,其它31 位表示整数值的长度和大小。

5、bigint

bigint数据类型存储从-2^63 (-9 223372036854775807) 到2^63-1( 9223372036854775807) 之间的所有正负整数。
每个BIGINT 类型的数据占用8个字节的存储空间。

二、 浮点数据类型

浮点数据类型用于存储十进制小数。浮点数值的数据在SQL Server 中采用上舍入(Round up 或称为只入不舍)方式进行存储。
所谓上舍入是指,当(且仅当)要舍入的数是一个非零数时,对其保留数字部分的最低有效位上的数值加1 ,并进行必要的进位。若一个数是上舍入数,其绝对值不会减少。
如:对3.14159265358979 分别进行2 位和12位舍入,结果为3.15 和3.141592653590。

1、real: 近似数值型

real数据类型可精确到第7 位小数,其范围为从-3.40E -38 到3.40E +38。 每个real类型的数据占用4 个字节的存储空间。

2、float[(n)]:近似数值型

float数据类型可精确到第15 位小数,其范围为从-1.79E -308 到1.79E +308。 每个FLOAT 类型的数据占用8 个字节的存储空间。
float数据类型可写为FLOAT[ n ]的形式。n 指定float数据的精度。n 为1到15 之间的整数值。当n 取1 到7 时,实际上是定义了一个real类型的数据,系统用4 个字节存储它;
当n 取8 到15 时,系统认为其是float类型,用8 个字节存储它。

3、decimal[p [s] ]

decimal数据类型可以提供小数所需要的实际存储空间,但也有一定的限制,您可以用2 到17 个字节来存储从-10的38次方-1 到10的38次方-1 之间的数值。
可将其写为decimal[ p [s] ]的形式,p 和s 确定了精确的比例和数位。其中p 表示可供存储的值的总位数(不包括小数点),缺省值为18; s 表示小数点后的位数,缺省值为0。
例如:decimal (15 5),表示共有15 位数,其中整数10 位,小数5。

4、numeric[p [s] ]

numeric数据类型与decimal数据类型完全相同。
注意:SQL Server 为了和前端的开发工具配合,其所支持的数据精度默认最大为28位。但可以通过使用命令来执行sqlserver.exe程序以启动SQL Server,可改变默认精度。

5、smallMoney货币型

smallMoney 数据类型用来表示钱和货币值。这种数据类型能存储从-214748.3648 到214748.3647 之间的数据,精确到货币单位的万分之一。smallmoney 数据类型要求4 个存储字节。

6、money货币型

money数据类型用来表示钱和货币值。这种数据类型能存储从-9220亿到9220 亿之间的数据,精确到货币单位的万分之一。money数据类型要求8 个存储字节。

三、字符数据类型

字符数据类型是使用最多的数据类型。它可以用来存储各种字母、数字符号、特殊符号。一般情况下,使用字符类型数据时须在其前后加上单引号’或双引号” 。

1、char[(n)]

char数据类型的定义形式为char[(n)] 。 以char类型存储的每个字符和符号占一个字节的存储空间。n 表示所有字符所占的存储空间,n 的取值为1 到8000,
即可容纳8000 个ANSI 字符。若不指定n 值,则系统默认值为1。若输入数据的字符数小于n,则系统自动在其后添加空格来填满设定好的空间。若输入的数据过长,将会截掉其超出部分。

如果没有在数据定义或变量声明语句中指定 n,则默认长度为 1如果在使用 CAST 和 CONVERT 函数时未指定 n,则默认长度为 30。

2、nchar[(n)]

nchar数据类型的定义形式为nchar[(n)]。 它与char类型相似。不同的是nchar数据类型n的取值为1 到4000。 因为nchar类型采用UNICODE 标准字符集(CharacterSet)。
UNICODE 标准规定每个字符占用两个字节的存储空间,所以它比非UNICODE 标准的数据类型多占用一倍的存储空间。使用UNICODE 标准的好处是因其使用两个字节做存储单位,
其一个存储单位的容纳量就大大增加了,可以将全世界的语言文字都囊括在内,在一个数据列中就可以同时出现中文、英文、法文、德文等,而不会出现编码冲突。

3、varchar[(n| max )]

varchar数据类型的定义形式为varchar[(n| max )]。 它与char类型相似,n 的取值也为1 到8000,若输入的数据过长,将会截掉其超出部分。
不同的是,varchar数据类型具有变动长度的特性,因为varchar数据类型的存储长度为实际数值长度,若输入数据的字符数小于n ,则系统不会在其后添加空格来填满设定好的空间。
一般情况下,由于char数据类型长度固定,因此它比varchar类型的处理速度快。

4、nvarchar[(n| max )]

nvarchar数据类型的定义形式为nvarchar[ ( n |max) ]。它与varchar类型相似。不同的是,nvarchar数据类型采用UNICODE 标准字符集(Character Set), n 的取值为1 到4000。

5、text

text数据类型用于存储大量文本数据,其容量理论上为1 到2的31次方-1 (2147483647)个字节,在实际应用时需要视硬盘的存储空间而定。
SQL Server 中,将text和image 类型的数据直接存放到表的数据行中。

6 、ntext

ntext数据类型与text类型相似不同的,是ntext类型采用UNICODE 标准字符集(Character Set), 因此其理论容量为230-1(1073741823)个字节。

四、 日期和时间数据类型

日期和时间数据类型及函数 - SQL Server (Transact-SQL) | Microsoft 官方文档

1、datetime :日期和時間(1753-1-1 日到 9999-12-31)

datetime 数据类型用于存储日期和时间的结合体。它可以存储从公元1753 年1 月1 日零时起到公元9999 年12 月31 日23 时59 分59 秒之间。精确到三百分之一秒或3.33毫秒

2、dateTime2 (n):高精度的datetime类型(0001-01-01 到 9999-12-31)

类似于之前的datetime类型,不过其精度比较高,可以精确到小数点后面7位(100ns),其使用语法为:datetime2(n)。
0001-01-01 00:00:00.0000000到9999-12-31 23:59:59:9999999,表示日期和时间

使用示例:

declare @dt as datetime2(5)
set @dt = getdate()
select @dt

3、smalldatetime:精确到分钟,日期和時間。(1900-01-01 到 2079-06-06)不推荐。

smalldatetime 数据类型用来表示小范围间的日期和时间,精确到一分钟。

4、date:只表示日期:年-月-日(0001-01-01 到 9999-12-31)

按照年-月-日的格式表示日期

5、time:只表示时间:hh:mm:ss(00:00:00.0000000 到 23:59:59.9999999)

按照hh:mm:ss的格式精确表示时间

6、datetimeOffset:时间部分增加时区表示

加入了时区偏移量部分,时区偏移量表示为 [+|-] HH:MM。 必需的 + 或 - 符号指示在 UTC(通用协调时间或格林尼治标准时间)中是加上还是减去时区偏移量以获取本地时间。

00000-01-01 00:00:00.0000000到99999-12-31 23:59:59:9999999

使用示例:

declare @dt as datetimeoffset(8)
set @dt = '2008-08-08 08:08:08.0 +8:00'
select @dt

五、二进制数据类型

1、binary

binary数据类型用于存储二进制数据。其定义形式为binary(n), n 表示数据的长度,取值为1 到8000 。
在使用时必须指定binary类型数据的大小,至少应为1 个字节。BINARY 类型数据占用n+4 个字节的存储空间。
在输入数据时必须在数据前加上字符“0X” 作为二进制标识,如:要输入“abc ”则应输入“0xabc ”。
若输入的数据过长将会截掉其超出部分。若输入的数据位数为奇数,则会在起始符号“0X ”后添加一个0,如上述的“0xabc ”会被系统自动变为“0x0abc”。

2、varbinary

varbinary 数据类型的定义形式为varbinary(n)。 它与binary类型相似,n 的取值也为1 到8000,若输入的数据过长,将会截掉其超出部分。
不同的是varbinary数据类型具有变动长度的特性,因为varbinary数据类型的存储长度为实际数值长度+4个字节。当binary数据类型允许NULL 值时,将被视为varbinary数据类型。
一般情况下,由于BINARY 数据类型长度固定,因此它比varbinary 类型的处理速度快。

3、image

image 数据类型用于存储大量的二进制数据Binary Data。其理论容量为2的31次方-1(2147483647)个字节。其存储数据的模式与text数据类型相同。
通常用来存储图形等OLE Object Linking and Embedding对象连接和嵌入对象。在输入数据时同BINARY数据类型一样,必须在数据前加上字符“0X”作为二进制标识。应用程序可以使用BMP、TIEF、GIF 和 JPEG 格式把数据存储在image 数据类型中。

六、特殊数据类型

1、 cursor:游标引用

cursor 数据类型是一种特殊的数据类型,它包含一个对游标的引用。这种数据类型用在存储过程中,而且创建表时不能用。

T-SQL游标

2、timestamp:时间戳

timestamp 数据类型是一种特殊的数据类型,用来创建一个数据库范围内的唯一数码。 一个表中只能有一个timestamp列。每次插入或修改一行时,timestamp列的值都会改变。Timestamp 用于表示SQL Server 活动的先后顺序。尽管它的名字中有“time”, 但timestamp列不是人们可识别的日期。在一个数据库里,timestamp值是唯一的 。timestamp的数据类型为rowVersion数据类型的同义词。

3、uniqueIdentifier:全局唯一标识符,即GUID

uniqueIdentifier数据类型用来存储一个全局唯一标识符,即GUID。由 16 字节的十六进制数字组成。GUID确实是全局唯一的。这个数几乎没有机会在另一个系统中被重建。可以使用NEWID 函数或转换一个字符串为唯一标识符来初始化具有唯一标识符的列。

例如:6F9619FF-8B86-D011-B42D-00C04FC964FF,此号码可以通过newid()函数获得,在全世界各地的计算机由此函数产生的数字不会相同。

4、sql_variant:SQL变量

用于存储除文本,图形数据和timestamp数据外的其它任何合法的Sql Server数据,可以方便Sql Server的开发工作。

5、table:表

用于存储对表或视图处理后的结果集。这种新的数据类型使得变量可以存储一个表,从而使函数或过程返回查询结果更加方便、快捷。

6、xml

存储xml数据的数据类型。可以在列中或者xml类型的变量中存储xml实例。存储的xml数据类型表示实例大小不能超过2GB。

SQL ServerXML类型

七、SQL Server 2008新增数据类型

hierarchid

新增的数据类型,用于创建层次结构的表,或引用位于另一位置的数据层次结构。

吉特日化MES & SQL Server中的数据类型的更多相关文章

  1. SQL Server 中使用数据类型表示小数

    在使用的时候发现一个问题,由于编程的习惯,当数据库中需要存储小数的时候,就想当然的使用了float类型,可结果太让人意外了. 数据库中存储了0.5没问题,当使用0.6的时候,得到的确是0.599999 ...

  2. SQL Server中的数据类型

    参考 SQL Server 2012编程入门经典(第4版) SQL Server 自带的数据类型 整型: 货币 近似小数 日期/时间 特殊数字 字符 Unicode 二进制 其他

  3. sql server 中xml 数据类型的insert、update、delete

    近日对SQL操作XML作了如下整理: 1.插入 XML DECLARE @myDoc XMLSET @myDoc = '<Root> <ProductDescription Prod ...

  4. SQL Server中datetimeset转换datetime类型问题浅析

    在SQL Server中,数据类型datetimeoffset转换为datetime类型或datetime2类型时需要特别注意,有可能一不小心你可能会碰到下面这种情况.下面我们构造一个简单案例,模拟一 ...

  5. SQL Server中的高可用性(2)----文件与文件组

        在谈到SQL Server的高可用性之前,我们首先要谈一谈单实例的高可用性.在单实例的高可用性中,不可忽略的就是文件和文件组的高可用性.SQL Server允许在某些文件损坏或离线的情况下,允 ...

  6. SQL Server中SELECT会真的阻塞SELECT吗?

    在SQL Server中,我们知道一个SELECT语句执行过程中只会申请一些意向共享锁(IS) 与共享锁(S), 例如我使用SQL Profile跟踪会话86执行SELECT * FROM dbo.T ...

  7. Microsoft SQL Server中的事务与并发详解

    本篇索引: 1.事务 2.锁定和阻塞 3.隔离级别 4.死锁 一.事务 1.1 事务的概念 事务是作为单个工作单元而执行的一系列操作,比如查询和修改数据等. 事务是数据库并发控制的基本单位,一条或者一 ...

  8. SQL Server中TOP子句可能导致的问题以及解决办法

    简介      在SQL Server中,针对复杂查询使用TOP子句可能会出现对性能的影响,这种影响可能是好的影响,也可能是坏的影响,针对不同的情况有不同的可能性.      关系数据库中SQL语句只 ...

  9. 在SQL Server中为什么不建议使用Not In子查询

        在SQL Server中,子查询可以分为相关子查询和无关子查询,对于无关子查询来说,Not In子句比较常见,但Not In潜在会带来下面两种问题: 结果不准确 查询性能低下       下面 ...

  10. SQL Server中提前找到隐式转换提升性能的办法

        http://www.cnblogs.com/shanksgao/p/4254942.html 高兄这篇文章很好的谈论了由于数据隐式转换造成执行计划不准确,从而造成了死锁.那如果在事情出现之前 ...

随机推荐

  1. LeetCode 周赛上分之旅 #40 结合特征压缩的数位 DP 问题

    ️ 本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 和 BaguTree Pro 知识星球提问. 学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越 ...

  2. 《SQL与数据库基础》23. 读写分离

    目录 读写分离 一主一从 准备 配置 双主双从 准备 配置 主库配置 从库配置 从库关联主库 主库相互复制 双主双从读写分离 本文以 MySQL 为例.以 MyCat 数据库中间件为例,通过 MyCa ...

  3. SQL Server更改表字段顺序和表结构

    1.首先打开SqlServer,SSMS可视化工具.点击工具,再点选项. 2.在弹出的选项窗口中,点击Desinners,点击表设计和数据库设计器,将阻止保护勾去掉.点"确定" 3 ...

  4. python实现简单的爬虫功能

    前言Python是一种广泛应用于爬虫的高级编程语言,它提供了许多强大的库和框架,可以轻松地创建自己的爬虫程序.在本文中,我们将介绍如何使用Python实现简单的爬虫功能,并提供相关的代码实例. 如何实 ...

  5. Go语言系列——01-HelloWorld、02-命名规范、03-变量、04-类型、05-常量、06-函数(Function)、07-包、08-if-else语句、09-循环、10-switch语句

    文章目录 01-HelloWorld 一 建立 Go 工作区 二 运行 Go 程序 2.1 hello world 程序代码介绍 02-开发环境搭建 一 下载地址 二 安装 Linux安装 Windo ...

  6. Go 代码块与作用域,变量遮蔽问题详解

    Go 代码块与作用域详解 目录 Go 代码块与作用域详解 一.引入 二.代码块 (Block) 2.1 代码块介绍 2.2 显式代码块 2.3 隐式代码块 2.4 空代码块 2.5 支持嵌套代码块 三 ...

  7. ubuntu 20.1 (linux) 下软件安装教程(基本上都是使用命令行安装)

    一.node 1. 安装教程 # 第二步,添加源后安装 需要什么版本直接替换后面的数字即可,如果需要21,直接将20替换为21就可以了 curl -sL https://deb.nodesource. ...

  8. Rust学习 | Rustlings通关记录与题解

    2023年6月19日决定对rust做一个重新的梳理,整理今年4月份做完的rustlings,根据自己的理解来写一份题解,记录在此. 周折很久,因为中途经历了推免的各种麻烦事,以及选择数据库作为未来研究 ...

  9. js数据结构--字典

    <!DOCTYPE html> <html> <head> <title></title> </head> <body&g ...

  10. Vue之自定义过滤器

    使用Vue.filter('过滤器名称',方法); 1. <!DOCTYPE html> <html lang="en"> <head> < ...