SQL Server 里的int型取值范围是多少

SQL Server 里的int型取值范围是多少,第1张

SQLServer中int的默认长度是4,即4个32位字节数据范围从-2^31(-2,147,483,648)到2^31-1(2,147,483,647)用于int的sql-92单词是integer。

在支持整数值的地方支持Int数据类型。但是,在某些特殊情况下不能使用int,当整数值超过int数据类型支持的范围时可以使用bigint。在SQLServer中,int数据类型是主要的整数数据类型。

扩展资料:

当转换成int,短整型,非常小的整数或bigint恒定值浮动,真实,小数,或数值数据类型隐式或显式地使用算术运算符(+,-,*,/或%,规则应用在评估精度的数据类型和表达式的结果取决于不同自动参数化查询。

因此,查询中相似的表达式有时会产生不同的结果。如果查询没有自动参数化,则在将常量值转换为指定的数据类型之前,首先将其转换为数值,该数据类型足够精确,可以保存常量的值。例如,常数值1被转换为数值(1,0),而常数值250被转换为数值(3,0)。

mysql 数据库float,int,bigint,double区别

单精度浮点数(float)的尾数是用24bit表示的,双精度(double)浮点数的尾数是用53bit表示的,转换成十进制: 2^24 - 1 = 16777215 2^53 - 1 = 9007199254740991 由上可见,IEEE754单精度浮点数的有效数字二进制是24位,按十进制来说

数据类型

Microsoft®

SQL

Server™

中,每个列、局部变量、表达式和参数都有一个相关的数据类型,这是指定对象可持有的数据类型(整型、字符、money

等等)的特性。SQL

Server

提供系统数据类型集,定义了可与

SQL

Server

一起使用的所有数据类型。下面列出系统提供的数据类型集。

可以定义用户定义的数据类型,其是系统提供的数据类型的别名。有关用户定义的数据类型的更多信息,请参见

sp_addtype

和创建用户定义的数据类型。

当两个具有不同数据类型、排序规则、精度、小数位数或长度的表达式通过运算符进行组合时:

通过将数据类型的优先顺序规则应用到输入表达式的数据类型来确定所得值的数据类型。有关更多信息,请参见数据类型的优先顺序。

如果结果数据类型为

char、varchar、text、nchar、nvarchar

ntext,则结果值的排序规则由排序规则的优先顺序规则决定。有关更多信息,请参见排序规则的优先顺序。

结果的精度、小数位数及长度取决于输入表达式的精度、小数位数及长度。有关更多信息,请参见精度、小数位数和长度。

SQL

Server

SQL-92

兼容性提供了数据类型同义词。有关更多信息,请参见数据类型同义词。

精确数字

整数

bigint

-2^63

(-9223372036854775808)

2^63-1

(9223372036854775807)

的整型数据(所有数字)。

int

-2^31

(-2,147,483,648)

2^31

-

1

(2,147,483,647)

的整型数据(所有数字)。

smallint

-2^15

(-32,768)

2^15

-

1

(32,767)

的整数数据。

tinyint

0

255

的整数数据。

bit

bit

1

0

的整数数据。

decimal

numeric

decimal

-10^38

+1

10^38

–1

的固定精度和小数位的数字数据。

numeric

功能上等同于

decimal。

money

smallmoney

money

货币数据值介于

-2^63

(-922,337,203,685,4775808)

2^63

-

1

(+922,337,203,685,4775807)

之间,精确到货币单位的千分之十。

smallmoney

货币数据值介于

-214,7483648

+214,7483647

之间,精确到货币单位的千分之十。

近似数字

float

-179E

+

308

179E

+

308

的浮点精度数字。

real

-340E

+

38

340E

+

38

的浮点精度数字。

datetime

smalldatetime

datetime

1753

1

1

日到

9999

12

31

日的日期和时间数据,精确到百分之三秒(或

333

毫秒)。

smalldatetime

1900

1

1

日到

2079

6

6

日的日期和时间数据,精确到分钟。

字符串

char

固定长度的非

Unicode

字符数据,最大长度为

8,000

个字符。

varchar

可变长度的非

Unicode

数据,最长为

8,000

个字符。

text

可变长度的非

Unicode

数据,最大长度为

2^31

-

1

(2,147,483,647)

个字符。

Unicode

字符串

nchar

固定长度的

Unicode

数据,最大长度为

4,000

个字符。

nvarchar

可变长度

Unicode

数据,其最大长度为

4,000

字符。sysname

是系统提供用户定义的数据类型,在功能上等同于

nvarchar(128),用于引用数据库对象名。

ntext

可变长度

Unicode

数据,其最大长度为

2^30

-

1

(1,073,741,823)

个字符。

二进制字符串

binary

固定长度的二进制数据,其最大长度为

8,000

个字节。

varbinary

可变长度的二进制数据,其最大长度为

8,000

个字节。

image

可变长度的二进制数据,其最大长度为

2^31

-

1

(2,147,483,647)

个字节。

其它数据类型

cursor

游标的引用。

sql_variant

一种存储

SQL

Server

支持的各种数据类型(text、ntext、timestamp

sql_variant

除外)值的数据类型。

table

一种特殊的数据类型,存储供以后处理的结果集。

timestamp

数据库范围的唯一数字,每次更新行时也进行更新。

uniqueidentifier

全局唯一标识符

(GUID)。

请参见

CREATE

PROCEDURE

CREATE

TABLE

DECLARE

@local_variable

EXECUTE

表达式

函数

LIKE

SET

sp_bindefault

sp_bindrule

sp_droptype

sp_help

sp_rename

sp_unbindefault

sp_unbindrule

使用

Unicode

数据

学号能用int或者bigint吗?学号只是标记,常理下用

varchar(几位学号就是长度几);名字嘛就是varchar(15)一般不会超过8个汉字吧;性别如果要是规定好的话(比如只能是‘男’或者‘女’)的话就用定长char(2) check in(‘男’,‘女’),否如果不确定填什么的话,就用varchar(5)。一般不会超过两个汉字吧。

(1) 整数型

整数包括bigint、int、smallint和tinyint,从标识符的含义就可以看出,它们的表示数范围逐渐缩小。

l bigint:大整数,数范围为 -263 (-9223372036854775808)~263-1 (9223372036854775807) ,其精度为19,小数位数为0,长度为8字节。

l int:整数,数范围为 -231 (-2,147,483,648) ~231 - 1 (2,147,483,647) ,其精度为10,小数位数为0,长度为4字节。

l smallint:短整数,数范围为 -215 (-32768) ~215 - 1 (32767) ,其精度为5,小数位数为0,长度为2字节。

l tinyint:微短整数,数范围为 0~255,长度为1字节,其精度为3,小数位数为0,长度为1字节。

(2) 精确整数型

精确整数型数据由整数部分和小数部分构成,其所有的数字都是有效位,能够以完整的精度存储十进制数。精确整数型包括decimal 和 numeric两类。从功能上说两者完全等价,两者的唯一区别在于decimal不能用于带有identity关键字的列。

声明精确整数型数据的格式是numeric | decimal(p[,s]),其中p为精度,s为小数位数,s的缺省值为0。例如指定某列为精确整数型,精度为6,小数位数为3,即decimal(6,3),那么若向某记录的该列赋值56342689时,该列实际存储的是563427。

decimal和numeric可存储从 -1038 +1 到 1038 –1 的固定精度和小数位的数字数据,它们的存储长度随精度变化而变化,最少为5字节,最多为17字节。

l 精度为1~9时,存储字节长度为5;

l 精度为10~19时,存储字节长度为9;

l 精度为20~28时,存储字节长度为13;

l 精度为29~38时,存储字节长度为17。

例如若有声明numeric(8,3),则存储该类型数据需5字节,而若有声明numeric(22,5),则存储该类型数据需13字节。

注意:声明精确整数型数据时,其小数位数必须小于精度;在给精确整数型数据赋值时,必须使所赋数据的整数部分位数不大于列的整数部分的长度。

(3) 浮点型

浮点型也称近似数值型。顾名思义,这种类型不能提供精确表示数据的精度,使用这种类型来存储某些数值时,有可能会损失一些精度,所以它可用于处理取值范围非常大且对精确度要求不是十分高的数值量,如一些统计量。

有两种近似数值数据类型:float[(n)]和real,两者通常都使用科学计数法表示数据,即形为:尾数E阶数,如56432E20,-298E10,1287659E-9等。

l real:使用4字节存储数据,表数范围为-340E + 38 到 340E + 38,数据精度为7位有效数字。

l float:定义中的n取值范围是1~53,用于指示其精度和存储大小。当n在1~24之间时,实际上是定义了一个real型数据,存储长度为4字节,精度为7位有效数字;当n在25~53之间时,存储长度为8字节,精度为15位有效数字。当缺省n时,代表n在25~53之间。float型数据的数范围为- 179E+308 到 179E+308。

(4) 货币型

SQL Server提供了两个专门用于处理货币的数据类型:money和smallmoney,它们用十进制数表示货币值。

l money:数据的数范围为-263 (-9223372036854775808)~263-1 (9223372036854775807) ,其精度为19,小数位数为4,长度为8字节。money的数的范围与bigint相同,不同的只是money型有4位小数,实际上,money就是按照整数进行运算的,只是将小数点固定在末4位。

l smallmoney:数范围为 –231 (-2,147,483648) ~231 - 1 (2,147,483647) ,其精度为10,小数位数为4,长度为4字节。可见smallmoney与int的关系就如同money与bigint的关系。

当向表中插入money或smallmoney类型的值时,必须在数据前面加上货币表示符号($),并且数据中间不能有逗号(,);若货币值为负数,需要在符号$的后面加上负号(-)。例如:$1500032,$680,$-200009088都是正确的货币数据表示形式。

(5) 位型

SQL Server中的位(bit)型数据相当于其他语言中的逻辑型数据,它只存储0和1,长度为一个字节。但要注意,SQL Server对表中bit类型列的存储作了优化:如果一个表中有不多于 8 个的bit列,这些列将作为一个字节存储,如果表中有 9 到 16 个 bit 列,这些列将作为两个字节存储,更多列的情况依此类推。

当为bit类型数据赋0时,其值为0,而赋非0(如100)时,其值为1。

若表中某列为bit类型数据,那么该列不允许为空值(有关空值概念本节稍后即做介绍),并且不允许对其建立索引。

(6) 字符型

字符型数据用于存储字符串,字符串中可包括字母、数字和其它特殊符号(如#、@、&等等)。在输入字符串时,需将串中的符号用单引号或双引号括起来,如’abc’、”Abc<Cde”。

SQL Server字符型包括两类:固定长度 (char) 或可变长度 (varchar) 字符数据类型。

l char[(n)]

定长字符数据类型,其中n定义字符型数据的长度,n在1到8000之间,缺省为1。当表中的列定义为char(n)类型时,若实际要存储的串长度不足n时,则在串的尾部添加空格以达到长度n,所以char(n)的长度为n。例如某列的数据类型为char(20),而输入的字符串为”ahjm1922”,则存储的是字符ahjm1922和12个空格。若输入的字符个数超出了n,则超出的部分被截断。

l varchar[(n)]

变长字符数据类型,其中n的规定与定长字符型char中n完全相同,但这里n表示的是字符串可达到的最大长度。varchar(n)的长度为输入的字符串的实际字符个数,而不一定是n。例如,表中某列的数据类型为varchar(100),而输入的字符串为”ahjm1922”,则存储的就是字符ahjm1922,其长度为8字节。

当列中的字符数据值长度接近一致时,例如姓名,此时可使用 char;而当列中的数据值长度显著不同时,使用varchar较为恰当,可以节省存储空间。

(7) Unicode字符型

Unicode是“统一字符编码标准”,用于支持国际上非英语语种的字符数据的存储和处理。SQL Server的Unicode字符型可以存储Unicode标准字符集定义的各种字符。

Unicode字符型包括nchar[(n)]和nvarchar[(n)]两类。nchar是固定长度 Unicode 数据的数据类型,nvarchar 是可变长度 Unicode 数据的数据类型,二者均使用 UNICODE UCS-2 字符集。

l nchar[(n)]:nchar[(n)]为包含n个字符的固定长度 Unicode 字符型数据,n 的值在 1 与 4,000 之间,缺省为1。长度为2n字节。若输入的字符串长度不足n,将以空白字符补足。

l nvarchar[(n)]:nvarchar[(n)]为最多包含n个字符的可变长度 Unicode 字符型数据,n 的值在 1 与 4,000之间,缺省为1。长度是所输入字符个数的两倍。

实际上,nchar、nvarchar与char、varchar的使用非常相似,只是字符集不同(前者使用Unicode字符集,后者使用ASCII字符集)。

(8) 文本型

当需要存储大量的字符数据,如较长的备注、日志信息等等,字符型数据的最长8000个字符的限制可能使它们不能满足这种应用需求,此时可使用文本型数据。

文本型包括text和ntext两类,分别对应ASCII字符和Unicode字符。text类型可以表示最大长度为 231-1 (2,147,483,647) 个字符,其数据的存储长度为实际字符数个字节。ntext可表示最大长度为 230 - 1 (1,073,741,823) 个Unicode字符,其数据的存储长度是实际字符个数的两倍(以字节为单位)。

(9) 二进制型

二进制数据类型表示的是位数据流,包括binary(固定长度)和varbinary(可变长度)两种。

l binary [(n) ]:固定长度的n个字节二进制数据。n取值范围为 1 到 8,000,缺省为1。binary(n)数据的存储长度为 n+4 字节。若输入的数据长度小于n,则不足部分用0填充;若输入的数据长度大于n,则多余部分被截断。

输入二进制值时,在数据前面要加上0x,可以用的数字符号为0—9、A—F(字母大小写均可)。因此,二进制数据有时也被称为十六进制数据。例如0xFF、0x12A0分别表示值FF和12A0。因为每字节的数最大为FF,故在“0x”格式的数据每两位占1个字节。

l varbinary [(n) ]:n个字节变长二进制数据。n取值范围为 1 到 8,000,缺省为1。varbinary(n)数据的存储长度为实际输入数据长度+4个字节。

(10) 日期时间类型

日期时间类型数据用于存储日期和时间信息,包括datetime和smalldatetime两类。

l datetime:datetime类型可表示的日期范围从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确度为百分之三秒(333 毫秒或 000333 秒),例如1到3毫秒的值都表示为0毫秒,4到6毫秒的值都表示为4毫秒。

datetime类型数据长度为8字节,日期和时间分别使用4个字节存储。前4 字节用于存储datetime类型数据中距1900 年 1 月 1 日的天数,为正数表示日期在1900年1月1日之后,为负数则表示日期在1900年1月1日之前。后4个字节用于存储datetime类型数据中距12:00(24小时制)的毫秒数。

用户以字符串形式输入datetime类型数据,系统也以字符串形式输出datetime类型数据,将用户输入到系统以及系统输出的datetime类型数据的字符串形式称为datetime类型数据的“外部形式”,而将datetime在系统内的存储形式称为“内部形式”,SQL Server负责datetime类型数据的两种表现形式之间的转换,包括合法性检查。

用户给出datetime类型数据值时,日期部分和时间部分分别给出。

日期部分的表示形式常用的格式如下:

年 月 日 2001 Jan 20、2001 Janary 20

年 日 月 2001 20 Jan

月 日[,]年 Jan 20 2001、Jan 20,2001、Jan 20,01

月 年 日 Jan 2001 20

日 月[,]年 20 Jan 2001、20 Jan,2001

日 年 月 20 2001 Jan

年(4位数) 2001表示2001年1月1日

年月日 20010120、010120

月/日/年 01/20/01、1/20/01、01/20/2001、1/20/2001

月-日-年 01-20-01、1-20-01、01-20-2001、1-20-2001

月日年 012001、12001、01202001、1202001

说明:年可用4位或2位表示,月和日可用1位或2位表示。

时间部分常用的表示格式如下:

时:分 10:20、08:05

时:分:秒 20:15:18、20:15:182

时:分:秒:毫秒 20:15:18:200

时:分AM|PM 10:10AM、10:10PM

l smalldatetime:smalldatetime类型数据可表示从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间,数据精确到分钟,即29998 秒或更低的值向下舍入为最接近的分钟,29999 秒或更高的值向上舍入为最接近的分钟。Smalldatetime类型数据的存储长度为4字节,前2个字节用来存储smalldatetime类型数据中日期部分距1900年1月1日之后的天数;后2个字节用来存储smalldatetime类型数据中时间部分距中午12点的分钟数。

用户输入smalldatetime类型数据的格式与datetime类型数据完全相同,只是它们的内部存储可能不相同。

(11) 时间戳型

标识符是timestamp。若创建表时定义一个列的数据类型为时间戳类型,那么每当对该表加入新行或修改已有行时,都由系统自动将一个计数器值加到该列,即将原来的时间戳值加上一个增量。记录timestamp列的值实际上反映了系统对该记录修改的相对(相对于其他记录)顺序。一个表只能有一个timestamp 列。Timestamp类型数据的值实际上是二进制格式数据,其长度为8字节。

(12) 图象数据类型

标识符是image,它用于存储、照片等。实际存储的是可变长度二进制数据,介于 0 与 231-1 (2,147,483,647) 字节之间。

(13) 其它数据类型

除了上面所介绍的常用数据类型外,SQL Server 2000还提供了其它几种数据类型:cursor、sql_variant、table和uniqueidentifier。

Cursor:是游标数据类型,用于创建游标变量或定义存储过程的输出参数。

Sql_variant:是一种存储 SQL Server 支持的各种数据类型(除text、ntext、image、timestamp 和 sql_variant 外)值的数据类型。Sql_variant的最大长度可达 8016 字节。

Table:是用于存储结果集的数据类型,结果集可以供后续处理。

Uniqueidentifier:是唯一标识符类型。系统将为这种类型的数据产生唯一标识值,它是一个16字节长的二进制数据。

sql

server

2005

里不能设置int数据类型的长度

如果你想节省空间,你可以改变数据类型

int

数据类型在数据库中占4个字节

smallint

数据类型占2个字节

tinyint

占1个字节

取值范围从

0~255

之间的整数

以上就是关于SQL Server 里的int型取值范围是多少全部的内容,包括:SQL Server 里的int型取值范围是多少、mysql 数据库float,int,bigint,double区别、SQL 数据库 数据类型 固定长度的字符串怎么定义等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9532585.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存