怎么使用SQL语句查MySQL数据库中数据表的字符集类型

怎么使用SQL语句查MySQL数据库中数据表的字符集类型,第1张

查看数据库的字符

show variables like 'character\_set\_%';

输出:

+--------------------------+--------+

| Variable_name | Value |

+--------------------------+--------+

| character_set_client | latin1 |

| character_set_connection | latin1 |

| character_set_database | latin1 |

| character_set_filesystem | binary |

| character_set_results | latin1 |

| character_set_server | latin1 |

| character_set_system | utf8 |

+--------------------------+--------+

数据库表中字段类型有二进制数据类型、字符数据类型、数字数据类型 等其中类型。具体类型如下所示:

1、二进制数据类型 

Binary、Varbinary、Image 

2、字符数据类型 

Char,Varchar和 Text

3、Unicode数据类型

包括Nchar,Nvarchar和Ntext

4、日期和时间数据类型

包括Datetime, Smalldatetime, Date, TimeStamp

5、数字数据类型

数字数据类型包括正数和负数、小数和整数

6、货币数据类型

表示正的或者负的货币数量。

7、特殊数据类型

特殊的数据类型有3种,即Timestamp、Bit 和 Uniqueidentifier。

SQL数据类型详解

bit 整型

其值只能是0、1或空值。

这种数据类型用于存储只有两种可能值的数据,如Yes 或No、True 或False 、On

或Off

int 整型 4个字节

从- 2^31(-2147483648)到2^31 (2147483

647)之间的整数。

存储到数据库的几乎所有数值型的数据都可以用这种数据类型。

smallint 整型 2个字节

smallint 数据类型可以存储从- 2^15(-32768)到2^15(32767)之间的整数。

tinyint 整型 1个字节

tinyint 数据类型能存储从0到255 之间的整数。

numeric 、 decimal 精确数值型

从-1038-1到1038-1的固定精度和范围的数值型数据。

使用这种数据类型时,必须指定范围和精度。

范围是小数点左右所能存储的数字的总位数,精度是小数点右边存储的数字的位数。

money 货币型

这种数据类型能存储从-9220亿到9220 亿之间的数据,精确到货币单位的万分之一。

smallmoney 货币型

这种数据类型能存储从-2147483648 到2147483647

之间的数据,精确到货币单位的万分之一。

float 浮点数值型

从-179E+308到179E+308 之间的任意数。

real 实型

在-340E+38到340E+38之间的浮点数。

datetime 日期时间型

从1753年1月1日到9999年12月31日间所有的日期和时间数据,精确到三百分之一秒或333毫秒。

Smalldatetime 日期时间型

从1900年1月1日到2079年6月6日间的日期和时间,精确到一分钟。

cursor 特殊数据型

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

timestamp 特殊数据型

用来创建一个数据库范围内的唯一数码。

一个表中只能有一个timestamp列。每次插入或修改一行时,timestamp列的值都会改变。

Uniqueidentifier 特殊数据型

全局唯一标识符,即GUID。可以使用NEWID

函数或转换一个字符串为唯一标识符来初始化具有唯一标识符的列

char 字符型

存储指定长度的定长非统一编码型的数据。当定义一列为此类型时,你必须指定列长。

当你总能知道要存储的数据的长度时,此数据类型很有用。

此数据类型的列宽最大为8000

个字符

varchar 字符型

用来存储非统一编码型字符数据。与char

型不一样,此数据类型为变长。

当定义一列为该数据类型时,你要指定该列的最大长度。

它与char数据类型最大的区别是,存储的长度不是列长,而是数据的长度

text 字符型

用来存储大量的非统一编码型字符数据。

这种数据类型最多可以有2^31-1或20亿个双字节字符

nchar 统一编码字符型

用来存储定长统一编码字符型数据。统一编码用双字节结构来存储每个字符,而不是用单字节(普通文本中的情况)。它允许大量的扩展字符。此数据类型能存储4000种字符,使用的字节空间上增加了一倍

nvarchar 统一编码字符型

nvarchar

数据类型用作变长的统一编码字符型数据。此数据类型能存储4000种字符,使用的字节空间增加了一倍

ntext 统一编码字符型

ntext 数据类型用来存储大量的统一编码字符型数据。

这种数据类型能存储2^30

-1或将近10亿个字符,且使用的字节空间增加了一倍

binary 二进制数据类型

binary数据类型用来存储可达8000

字节长的定长的二进制数据。当输入表的内容接近相同的长度时,你应该使用这种数据类型

varbinary 二进制数据类型

varbinary 数据类型用来存储可达8000

字节长的变长的二进制数据。当输入表的内容大小可变时,你应该使用这种数据类型

image 二进制数据类型

image 数据类型用来存储变长的二进制数据,最大可达2^31-1或大约20亿字节

---------------------------------------------------

(1)二进制数据类型

二进制数据包括 Binary、Varbinary 和 Image

Binary

数据类型既可以是固定长度的(Binary),也可以是变长度的。

Binary[(n)] 是 n 位固定的二进制数据。其中,n 的取值范围是从 1 到

8000。其存储窨的大小是 n + 4 个字节。

Varbinary[(n)] 是 n 位变长度的二进制数据。其中,n 的取值范围是从 1 到

8000。其存储窨的大小是 n + 4个字节,不是n 个字节。

在 Image 数据类型中存储的数据是以位字符串存储的,不是由 SQL Server

解释的,必须由应用程序来解释。例如,应用程序可以使用BMP、TIEF、GIF 和 JPEG 格式把数据存储在 Image 数据类型中。

(2)字符数据类型

字符数据的类型包括 Char,Varchar 和 Text

字符数据是由任何字母、符号和数字任意组合而成的数据。

Varchar

是变长字符数据,其长度不超过 8KB。Char 是定长字符数据,其长度最多为 8KB。超过 8KB 的ASCII 数据可以使用Text数据类型存储。例如,因为

Html 文档全部都是 ASCII 字符,并且在一般情况下长度超过 8KB,所以这些文档可以 Text 数据类型存储在SQL Server 中。

(3)Unicode 数据类型

Unicode 数据类型包括 Nchar,Nvarchar 和Ntext

在 Microsoft SQL Server 中,传统的非

Unicode 数据类型允许使用由特定字符集定义的字符。在 SQL Server安装过程中,允许选择一种字符集。使用 Unicode

数据类型,列中可以存储任何由Unicode 标准定义的字符。在 Unicode

标准中,包括了以各种字符集定义的全部字符。使用Unicode数据类型,所战胜的窨是使用非 Unicode 数据类型所占用的窨大小的两倍。

在 SQL

Server 中,Unicode 数据以 Nchar、Nvarchar 和 Ntext

数据类型存储。使用这种字符类型存储的列可以存储多个字符集中的字符。当列的长度变化时,应该使用Nvarchar 字符类型,这时最多可以存储 4000

个字符。当列的长度固定不变时,应该使用 Nchar 字符类型,同样,这时最多可以存储4000 个字符。当使用 Ntext 数据类型时,该列可以存储多于 4000

个字符。

(4)日期和时间数据类型

日期和时间数据类型包括 Datetime 和

Smalldatetime两种类型

日期和时间数据类型由有效的日期和时间组成。例如,有效的日期和时间数据包括“4/01/98

12:15:00:00:00 PM”和“1:28:29:15:01AM

8/17/98”。前一个数据类型是日期在前,时间在后一个数据类型是霎时间在前,日期在后。在 Microsoft SQL

Server中,日期和时间数据类型包括Datetime 和 Smalldatetime 两种类型时,所存储的日期范围是从 1753 年 1 月 1

日开始,到9999 年12 月 31 日结束(每一个值要求 8 个存储字节)。使用 Smalldatetime 数据类型时,所存储的日期范围是 1900年 1

月 1日 开始,到 2079 年 12 月 31 日结束(每一个值要求 4

个存储字节)。

日期的格式可以设定。设置日期格式的命令如下:

Set DateFormat {format | @format

_var|

其中,format | @format_var 是日期的顺序。有效的参数包括 MDY、DMY、YMD、YDM、MYD 和

DYM。在默认情况下,日期格式为MDY。

例如,当执行 Set DateFormat YMD 之后,日期的格式为年 月 日 形式;当执行 Set

DateFormat DMY 之后,日期的格式为日 月有年 形式

(5)数字数据类型

数字数据只包含数字。数字数据类型包括正数和负数、小数(浮点数)和整数

整数由正整数和负整数组成,例如 39、25、0-2 和 33967。在

Micrsoft SQL Server 中,整数存储的数据类型是 Int,Smallint和 Tinyint。

Int 数据类型存储数据的范围大于 Smallint 数据类型存储数据的范围,而 Smallint 据类型存储数据的范围大于Tinyint

数据类型存储数据的范围。

使用 Int 数据狗昔存储数据的范围是从 -2 147 483 648 到 2 147 483 647(每一个值要求4个字节存储空间)。

使用 Smallint 数据类型时,存储数据的范围从 -32 768 到 32 767(每一个值要求2个字节存储空间)。

使用Tinyint 数据类型时,存储数据的范围是从0 到255(每一个值要求1个字节存储空间)。

精确小娄数据在 SQL Server

中的数据类型是 Decimal 和 Numeric。这种数据所占的存储空间根据该数据的位数后的位数来确定。

在SQL Server

中,近似小数数据的数据类型是 Float 和

Real。例如,三分之一这个分数记作。3333333,当使用近似数据类型时能准确表示。因此,从系统中检索到的数据可能与存储在该列中数据不完全一样。

(6)货币数据表示正的或者负的货币数量 。

在 Microsoft SQL Server 中,货币数据的数据类型是Money 和 Smallmoney

Money数据类型要求 8

个存储字节,Smallmoney 数据类型要求 4 个存储字节。

(7)特殊数据类型

特殊数据类型包括前面没有提过的数据类型。特殊的数据类型有3种,即 Timestamp、Bit 和

Uniqueidentifier。

Timestamp 用于表示SQL Server 活动的先后顺序,以二进投影的格式表示。Timestamp

数据与插入数据或者日期和时间没有关系。

Bit 由 1 或者 0 组成。当表示真或者假、ON 或者 OFF 时,使用 Bit

数据类型。例如,询问是否是每一次访问的客户机请求可以存储在这种数据类型的列中。

Uniqueidentifier 由 16

字节的十六进制数字组成,表示一个全局唯一的。当表的记录行要求唯一时,GUID是非常有用。例如,在客户标识号列使用这种数据类型可以区别不同的客户。

2用户定义的数据类型

用户定义的数据类型基于在 Microsoft SQL Server

中提供的数据类型。当几个表中必须存储同一种数据类型时,并且为保证这些列有相同的数据类型、长度和可空性时,可以使用用户定义的数据类型。例如,可定义一种称为

postal_code 的数据类型,它基于 Char

数据类型。

当创建用户定义的数据类型时,必须提供三个数:数据类型的名称、所基于的系统数据类型和数据类型的可空性。

(1)创建用户定义的数据类型

创建用户定义的数据类型可以使用 Transact-SQL 语句。系统存储过程 sp_addtype

可以来创建用户定义的数据类型。其语法形式如下:

sp_addtype

{type},[,system_data_bype][,'null_type']

其中,type

是用户定义的数据类型的名称。system_data_type 是系统提供的数据类型,例如 Decimal、Int、Char 等等。 null_type

表示该数据类型是如何处理空值的,必须使用单引号引起来,例如'NULL'、'NOT NULL'或者'NONULL'。

例子:

Use

cust

Exec sp_addtype ssn,'Varchar(11)',"Not Null'

创建一个用户定义的数据类型

ssn,其基于的系统数据类型是变长为11 的字符,不允许空。

例子:

Use cust

Exec sp_addtype

birthday,datetime,'Null'

创建一个用户定义的数据类型 birthday,其基于的系统数据类型是

DateTime,允许空。

例子:

Use master

Exec sp_addtype

telephone,'varchar(24),'Not Null'

Eexc sp_addtype

fax,'varchar(24)','Null'

创建两个数据类型,即 telephone 和 fax

(2)删除用户定义的数据类型

当用户定义的数据类型不需要时,可删除。删除用户定义的数据类型的命令是 sp_droptype {'type'}。

例子:

Use

master

Exec sp_droptype

'ssn'

注意:当表中的列还正在使用用户定义的数据类型时,或者在其上面还绑定有默认或者规则时,这种用户定义的数据类型不能删除。

SQL SERVER的字段类型说明

以下为SQL SERVER70以上版本的字段类型说明。SQL SERVER65的字段类型说明请参考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,4775808)到2^63-1(922,337,203,685,4775807)的货币数据,最小货币单位千分之十

smallmoney 从-214,7483648到214,7483647的货币数据,最小货币单位千分之十

float

从-179E+308到179E+308可变精度的数字

real 从-304E+38到304E+38可变精度的数字

datetime 从1753年1月1日到9999年12日31的日期和时间数据,最小时间单位为百分之三秒或333毫秒

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)

-------------------------------------

Bit

1位,值为0或1

Int

Integer

4字节,值为-2^31~2^31-1

Smallint

2字节,值为-2^15~2^15-1

Tinyint

1字节,值为0~255

Decimal (p,s)

数字数据,固定精度为P,宽度为S

Numeric

Money

8字节,存放货币类型,值为-2^63~2^63-1

Small money

4字节,存放货币类型,值为-2147483648~+2147483647近似数值数据类型

Float (n)

N在1~24之间,4字节,7位精度

N=1~7为real

N在25~53之间,8字节,15位精度

=8~15为float

Datetime

8字节,描述某天的日期和时刻,值的精确度为1/300秒

Smalldatetime

4字节,描述某天的日期和时刻,精度为分钟

Cursor

对游标的引用

Timestamp

8字节,存放在数据库内唯一的数据

Uniqueidentifier

16字节,存放全局唯一标识(GUID)

Char (n)

非unicode字符串的固定长度,n=1~8000

Character (n)

Varchar (n)

可变长度,非unicode字符串n=1~8000

Char varying(n)

Text

服务器代码页中可变长度非unicode数据。最大长度为2^31-1个字符

Nchar

固定长度unicode字符串n=1~4000

National character (n),

National char(n)

Nvarchar

固定长度unicode字符串n=1~4000

National

character varying(n)

Ntext

可变长度unicode数据,最大长度为2^30-1个字符

National text

Binary (n)

固定长度二进制数据,n在1~8000之间,存储空间为n+4字节

Varbinary (n)

可变长度二进制数据,n=1~8000

Binary varying (n)

Tmage

可变长度二进制数据,大小为0~2^31-1

注意:

1)

对于数值型数据类型,宽度(scale)是指存储在小数点后的数字位数,而精度(precision)是指能存储的包含小数点在内的所有数字位数。

2) money和small money的存储宽度为4。

3) 时间戳列值在每一行更新时系统自动更新,时间戳列不能是关键字或关键字的一部分。

4)

唯一标识数据类型不能使用算术 *** 作符(如+、-等),这种数据类型只能使用相等比较 *** 作。Unicode是所有字符集的一致存储数据的标准。它要使用两倍于非Unicode数据存储的存储空间。

CHAR(n)类型

int

ASCII

代码转换为字符的

字符串函数

。参数n是介于

0

255

之间的整数。如果整数表达式不在此范围内,将返回

NULL

值。

nchar

nvarchar

nchar

是固定长度

Unicode

数据的数据类型,nvarchar

是可变长度

Unicode

数据的数据类型,二者均使用

UNICODE

UCS-2

字符集

nchar(n)类型

包含

n

个字符的固定长度

Unicode

字符数据。n

的值必须介于

1

4,000

之间。存储大小为

n

字节的两倍。nchar

SQL-92

中的同义词为

national

char

national

character。

nvarchar(n)类型

包含

n

个字符的可变长度

Unicode

字符数据。n

的值必须介于

1

4,000

之间。字节的存储大小是所输入字符个数的两倍。所输入的数据字符长度可以为零。nvarchar

SQL-92

中的同义词为

national

char

varying

national

character

varying。

昨天一个同事的程序的除了问题,怎么都调不通,一开始以为是hibernate的问题,后来发现问题是他在一个数据表里用了index作为字段名,但是index是mysql的关键字,呵呵,有点粗心啦 查了一下,关键字(有的是保留字 )还真是不少在MySQL中,下表中的字显式被保留。其中大多数字进制被标准SQL用作列名和/或表名(例如,GROUP)。少数被保留了,因为MySQL需要它们,保留字被引起来后可以用作识别符。出

ADD ALL ALTER

ANALYZE AND AS

ASC ASENSITIVE BEFORE

BETWEEN BIGINT BINARY

BLOB BOTH BY

CALL CASCADE CASE

CHANGE CHAR CHARACTER

CHECK COLLATE COLUMN

CONDITION CONNECTION CONSTRAINT

CONTINUE CONVERT CREATE

CROSS CURRENT_DATE CURRENT_TIME

CURRENT_TIMESTAMP CURRENT_USER CURSOR

DATABASE DATABASES DAY_HOUR

DAY_MICROSECOND DAY_MINUTE DAY_SECOND

DEC DECIMAL DECLARE

DEFAULT DELAYED DELETE

DESC DESCRIBE DETERMINISTIC

DISTINCT DISTINCTROW DIV

DOUBLE DROP DUAL

EACH ELSE ELSEIF

ENCLOSED ESCAPED EXISTS

EXIT EXPLAIN FALSE

FETCH FLOAT FLOAT4

FLOAT8 FOR FORCE

FOREIGN FROM FULLTEXT

GOTO GRANT GROUP

HAVING HIGH_PRIORITY HOUR_MICROSECOND

HOUR_MINUTE HOUR_SECOND IF

IGNORE IN INDEX

INFILE INNER INOUT

INSENSITIVE INSERT INT

INT1 INT2 INT3

INT4 INT8 INTEGER

INTERVAL INTO IS

ITERATE JOIN KEY

KEYS KILL LABEL

LEADING LEAVE LEFT

LIKE LIMIT LINEAR

LINES LOAD LOCALTIME

LOCALTIMESTAMP LOCK LONG

LONGBLOB LONGTEXT LOOP

LOW_PRIORITY MATCH MEDIUMBLOB

MEDIUMINT MEDIUMTEXT MIDDLEINT

MINUTE_MICROSECOND MINUTE_SECOND MOD

MODIFIES NATURAL NOT

NO_WRITE_TO_BINLOG NULL NUMERIC

ON OPTIMIZE OPTION

OPTIONALLY OR ORDER

OUT OUTER OUTFILE

PRECISION PRIMARY PROCEDURE

PURGE RAID0 RANGE

READ READS REAL

REFERENCES REGEXP RELEASE

RENAME REPEAT REPLACE

REQUIRE RESTRICT RETURN

REVOKE RIGHT RLIKE

SCHEMA SCHEMAS SECOND_MICROSECOND

SELECT SENSITIVE SEPARATOR

SET SHOW SMALLINT

SPATIAL SPECIFIC SQL

SQLEXCEPTION SQLSTATE SQLWARNING

SQL_BIG_RESULT SQL_CALC_FOUND_ROWS SQL_SMALL_RESULT

SSL STARTING STRAIGHT_JOIN

TABLE TERMINATED THEN

TINYBLOB TINYINT TINYTEXT

TO TRAILING TRIGGER

TRUE UNDO UNION

UNIQUE UNLOCK UNSIGNED

UPDATE USAGE USE

USING UTC_DATE UTC_TIME

UTC_TIMESTAMP VALUES VARBINARY

VARCHAR VARCHARACTER VARYING

WHEN WHERE WHILE

WITH WRITE X509

XOR YEAR_MONTH ZEROFILL

MySQL允许部分关键字用做未引起来的识别符,因为许多人以前曾使用过它们。下面列出了一些例子:

ACTION

BIT

DATE

ENUM

NO

TEXT

TIME

TIMESTAMP

SQL 用于各种数据库的数据类型:

一、MySQL 数据类型:

在 MySQL 中,有三种主要的类型:Text(文本)、Number(数字)和 Date/Time(日期/时间)类型。

1、Text 类型。

2、Number 类型。这些整数类型拥有额外的选项 UNSIGNED。通常,整数可以是负数或正数。如果添加 UNSIGNED 属性,那么范围将从 0 开始,而不是某个负数。

3、Date 类型。

即便 DATETIME 和 TIMESTAMP 返回相同的格式,它们的工作方式很不同。在 INSERT 或 UPDATE 查询中,TIMESTAMP 自动把自身设置为当前的日期和时间。

TIMESTAMP 也接受不同的格式,比如 YYYYMMDDHHMMSS、YYMMDDHHMMSS、YYYYMMDD 或 YYMMDD。

二、SQL Server 数据类型:

1、String 类型。

2、Number 类型。

3、Date 类型。

4、其他数据类型。

扩展资料:

Microsoft Access的数据类型:

参考资料:

百度百科--SQL数据类型

以上就是关于怎么使用SQL语句查MySQL数据库中数据表的字符集类型全部的内容,包括:怎么使用SQL语句查MySQL数据库中数据表的字符集类型、数据库表中字段类型有哪些、怎么计算sql中数据类型的范围等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/sjk/9833764.html

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

发表评论

登录后才能评论

评论列表(0条)

保存