SQL Server数据库数据类型概述

在SQL Server中,设计表时需要定义表的列( column 的数据类型。  数据类型不合适可能导致各种问题,例如查询性能问题,数据截断(truncation)。本文简要介绍SQL Server支持数据类型。

SQL SERVER微软官方文档https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/data-types-transact-sql?view=sql-server-ver15 ,在此选择常用的简要总结介绍。

Character 字符串:

数据类型

描述

存储长度(字符数)

char(n)

固定长度的字符串。最多 8,000 个字符。

n <= 8000字符

varchar(n)

可变长度的字符串。最多 8,000 个字符。

0-n字符

varchar(max)

可变长度的字符串。最多 1,073,741,824 个字符。

0-max字符

text

可变长度的字符串。最多 2GB 字符数据。【不推荐,将弃用】

0-2GB字符

 

Unicode 字符串:

数据类型

描述

存储长度(字符数)

nchar(n)

固定长度的 Unicode 数据。最多 4,000 个字符。

 n <=4000字符

nvarchar(n)

可变长度的 Unicode 数据。最多 4,000 个字符。

 0-n <=4000 

nvarchar(max)

可变长度的 Unicode 数据。最多 536,870,912 个字符。

 0-536,870,912

ntext

可变长度的 Unicode 数据。最多 2GB 字符数据。 【不推荐,将弃用】

 0-2GB字符

特别说明varchar和nvarchar的区别:

varchar在SQL Server中是采用单字节来存储数据的,nvarchar是使用Unicode双字节来存储数据的。

英文字符占一个字节,在存储时,如果字段类型是varchar,则只会占用一个字节,而如果字段的类型为nvarchar,则会占用两个字节。

中文字符占两个字节,在存储时,不管字段类型是varchar,还是nvarchar,都占用两个字节(一般采用Unicode编码)。

【注:Unicode (统一码、 万国码、单一码 )是一种在计算机上使用的字符编码 。它为每种语言中的每个字符设定了统一并且唯一的二进制编码 ,以满足跨语言、跨平台进行文本转换 、处理的要求。】 

正常情况下varchar也可存储中文字符,但是如果遇到操作系统是英文操作系统,且对中文字体的支持不全面时, 在SQL Server存储中文字符为varchar就会出现乱码(显示为??);

解决问题办法的是把数据库字段的类型更改为nvarchar(或 者nchar)。

使用nvarchar类型,即可解决字符集兼容性问题(不用担心中文乱码问题),又可在判断字符串时不需要考虑中英文两种字符的差别.缺点是会增大一倍的存储空间。

所以一般来说,如果可能含有中文字符,用nchar/nvarchar存储,如果纯英文和数字(保证不含中文),则用char/varchar存储。

另外需要补充下,使用varchar存储字段,很可能会导致隐式转换;

     实例如下:创建AAA表,并插入1000条测试数据,并在name1上建索引,然后分别执行以下两行SQL语句,查看执行计划,发现第二个多了constant Scan的开销。

DECLARE @name VARCHAR(100)   SET @name = '张三500'  SELECT * FROM AAA WHERE  name1 = @name --varchar存储,参数类型为varchar,不存在隐式转换

DECLARE @name  NVARCHAR(100)  SET @name = '张三500'   SELECT * FROM  AAA   WHERE  name1 = @name  --varchar存储,参数类型为nvarchar,存在隐式转换

注:有时会出现,使用了nvarchar数据类型,但是系统仍出现中文乱码或者特殊符号乱码的问题;这时候在更新或者插入的字段值前面加上N即可;(如果是varchar类型的,加上N也不好使的)。

那么这个N是干什么用的呢?字符串参数值的前面有一个大写的N,它的含义是表明后面引号里的字符串是unicode。

总结一下:1、中文乱码问题,首先保证列的类型是nvarchar;2、然后插入数据的时候用“N”保证数据是unicode的。 这样就不会显示莫名其妙的问号、中文乱码或者特殊符号乱码了。

 

Binary 类型:

数据类型

描述

存储长度(字符数)

bit

允许 0、1 或 NULL

 1字节

binary(n)

固定长度的二进制数据。最多 8,000 字节。

 n <= 8000字节

varbinary(n)

可变长度的二进制数据。最多 8,000 字节。

 0-n字节

varbinary(max)

可变长度的二进制数据。最多 2GB 字节。

 0-2GB字节

image

可变长度的二进制数据。最多 2GB。 【不推荐,将弃用】

 0-2GB字节

Bit类型比较特殊,在SQL Server 2008中,使用SSMS可视工具给bit类型的列赋值时,需要输入True或False,而在查询数据时,则显示为1或0。而在使用SQL语句添加数据时,则需要使用1和0表示。

字节越大表示的整数范围越大,如果超过字节范围出会溢出。

 

Number 类型:

数据类型

描述

存储长度(字符数)

tinyint

允许从 0 到 255 的所有数字。

1字节

smallint

允许从 -32,768 到 32,767 的所有数字。

2字节

int

允许从 -2,147,483,648 到 2147483647 的所有数字。

4字节

bigint

允许介于 -9,223,372,036,854,775,808 和 9,223,372,036,854,775,807 之间的所有数字。

8字节

decimal(p,s)

固定精度和比例的数字。允许从 -10^38 +1 到 10^38 -1 之间的数字。

p 参数指示可以存储的最大位数(小数点左侧和右侧)。p 必须是 1 到 38 之间的值。默认是 18。

s 参数指示小数点右侧存储的最大位数。s 必须是 0 到 p 之间的值。默认是 0。

5-17字节

numeric(p,s)

固定精度和比例的数字。允许从 -10^38 +1 到 10^38 -1 之间的数字。

p 参数指示可以存储的最大位数(小数点左侧和右侧)。p 必须是 1 到 38 之间的值。默认是 18。

s 参数指示小数点右侧存储的最大位数。s 必须是 0 到 p 之间的值。默认是 0。

5-17字节

smallmoney

介于 -214,748.3648 和 214,748.3647 之间的货币数据。

4字节

money

介于 -922,337,203,685,477.5808 和 922,337,203,685,477.5807 之间的货币数据。

8字节

float(n)

从 -1.79E + 308 到 1.79E + 308 的浮动精度数字数据。 参数 n 指示该字段保存 4 字节还是 8 字节。float(24) 保存 4 字节,而 float(53) 保存 8 字节。n 的默认值是 53。

4或8字节

real

从 -3.40E + 38 到 3.40E + 38 的浮动精度数字数据。

4字节

float和real是SQL Server的浮点型,其中float表示双精度浮点数据类型,real表示单精度浮点数据类型。存储的是近似数值,不可用于等值比较。

SQL Server精确数据类型使用Decimal或Numeric表示,两者完全一样,建议使用Decimal类型。decimal(5,3)表示整数部分和小数部分最大一共是5位,其中小数最大为3位,则整数位最大就是2位,如果输入2位以上的整数部分就会出错,如果输入的小数位数超出指定的位数,则自动四舍五入。

SQL Server货币数据类型使用Smallmoney、money表示,数据值有整数部分和小数部分组成,小数部分精确到4位。小数位数多于4位,则会自动四舍五入。

 

Date 类型:

数据类型

描述

存储长度(字符数)

datetime

从 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度为 3.33 毫秒。

8 bytes

datetime2

从 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度为 100 纳秒。

6-8 bytes

smalldatetime

从 1900 年 1 月 1 日 到 2079 年 6 月 6 日,精度为 1 分钟。

4 bytes

date

仅存储日期。从 0001 年 1 月 1 日 到 9999 年 12 月 31 日。

3 bytes

time

仅存储时间。精度为 100 纳秒。

3-5 bytes

datetimeoffset

与 datetime2 相同,外加时区偏移。

8-10 bytes

timestamp

存储唯一的数字,每当创建或修改某行时,该数字会更新。timestamp 基于内部时钟,不对应真实时间。每个表只能有一个 timestamp 变量。

 8 bytes

 

其他数据类型:

数据类型

描述

sql_variant

存储最多 8,000 字节不同数据类型的数据,除了 text、ntext 以及 timestamp。

uniqueidentifier

存储全局标识符 (GUID)。GUID(Globally Unique Identifier)是一个通过特定算法产生的二进制长度为128位的数字标识符,用于指示产品的唯一性。

xml

存储 XML(eXtensible Markup Language)格式化数据,用来传输和存储数据。最多 2GB。

cursor

Cursor(游标)提供了在结果集中一次以行或者多行前进或向后浏览数据的能力。我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。

table

存储结果集,供稍后处理。

 

附录、

SQL在线练习网站 https://www.liaoxuefeng.com/wiki/1177760294764384/1179611432985088

提示:没办法保存,退出去内容就没了。

☆创建数据表的语法:
CREATE TABLE table_name (column_name column_type);

建立Persons表
CREATE TABLE Persons
(
PersonID int,
Name varchar(40),
Address varchar(80),
phone varchar(20)
);

☆向表中插入新记录。格式
INSERT INTO table_name
VALUES (value1,value2,value3,...);

INSERT INTO table_name(column1,column2,column3,...)
VALUES (value1,value2,value3,...);
如:
INSERT INTO Persons(PersonID,Name,Address,phone) VALUES(1,"张三","X1市a1区b1街c1号","11111111");
INSERT INTO Persons(PersonID,Name,Address,phone) VALUES(2,"李四","X1市a2区b2街c1号","22222222");
INSERT INTO Persons(PersonID,Name,Address,phone) VALUES(3,"王五","X2市m1区n1街M1号","33333333");

【注意,其中的逗号、引号是英文的】

☆查询——从表中读取数据
SELECT column_name,column_name
FROM table_name;

SELECT * FROM table_name;
如:
SELECT * FROM Persons;

☆条件查询,在查询语句后附上
WHERE 条件;

SELECT * FROM Persons
WHERE PersonID=2;

☆删除表
语法:
drop table 表名称;

drop table Persons;

猜你喜欢

转载自blog.csdn.net/cnds123/article/details/114830086