四、MySQL数据类型和运算符
  数据库表由多列字段构成,每⼀个字段指定了不同的数据类型。指定字段的数据类型之后,也就决定了向字段插⼊的数据内容。不同的数据类型也决定了MySQL在存储它们的时候使⽤的⽅式,以及在使⽤它们的时候选择什么运算符号进⾏运算。
⼀、MySQL数据类型介绍
  MySQL⽀持多种数据类型,主要有数值类型、⽇期/时间类型和字符串类型。
  (1)数值数据类型:包括整数类型TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT,浮点⼩数数据类型FLOAT和DOUBLE,定点⼩数类型DECIMAL。
  (2)⽇期/时间类型:包括YEAR、TIME、DATE、DATETIME和TIMESTAMP。
  (3)字符串类型:包括CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET等。字符串类型⼜分为⽂本字符串和⼆进制字符串。
1.1 整数类型curl post 传参数
cmd和dos的区别
  数值型数据类型主要⽤来存储数字,MySQL提供了多种数值数据类型,不同的数据类型提供不同的取值范围,可以存储的值范围越⼤,其所需的存储空间也会越⼤。MySQL主要提供的整数类型有:TINYINT、SMALLINT、MEDIUMINT、INT(INTEGER)、BIGINT。整数类型的属性字段可以添加AUTO_INCREMENT⾃增约束条件。下表列出了MySQL中的数值类型:
MySQL中的整数型数据类型
数据名称说明存储需求默认宽度值
TINYINT很⼩的整数1个字节4
SMALLINT⼩的整数2个字节6
MEDIUMINT中等⼤⼩的整数3个字节9
INT(INTEGER)普通⼤⼩的整数4个字节11
BIGINT⼤整数8个字节20
  根据占⽤字节数可以求出每⼀种数据类型的取值范围,例如TINYINT需要1个字节(8bits)来存储,
那么TINYINT⽆符号数的最⼤值为28-1,即255;TINYINT有符号数的最⼤值为27-1,即127。其他类型的整数的取值范围计算⽅法相同。
  在如下创建表的语句中:
CREATE TABLE test
(
  id INT(11),
  name VARCHAR(255)
)
  id字段的数据类型为INT(11),注意到后⾯的数字11,这表⽰的是该数据类型指定的显⽰宽度,指定能够显⽰的数值中数字的个数。例如,假设声明⼀个INT类型的字段:
year INT(4)
  该声明指明,在year字段中的数据⼀般只显⽰4位数字的宽度。
  在这⾥要注意:显⽰宽度与数据类型的取值范围是⽆关的。显⽰宽度只是指明MySQL最⼤可能显⽰的数字个数,数值的位数⼩于指定的宽度时会由空格填充;如果插⼊了⼤于显⽰宽度的值,只要该值不超过该类型整数的取值范围,数值依然可以插⼊,⽽且能够显⽰出来。
  其他整数类型也可以在定义表结构时指定所需要的显⽰宽度,如果不指定,则系统为每⼀种类型指定默认的宽度值。
1.2 浮点数类型和定点数类型
  MySQL中使⽤浮点数和定点数来表⽰⼩数。浮点类型有两种:单精度浮点类型(FLOAT)和双精度浮点类型(DOUBLE)。定点类型只有⼀种:DECIMAL。浮点类型和定点类型都可以⽤(M,N)来表⽰,其中M称为精度,表⽰总共的位数;N称为标度,是表⽰⼩数的位数。
MySQL中的⼩数类型
类型名称说明存储需求
FLOAT单精度浮点型4个字节
DOUBLE双精度浮点型8个字节
DECIMAL (M,D),DEC压缩的“严格”定点数M+2个字节
  DECIMAL类型不同于FLOAT和DOUBLE,DECIMAL实际是以串存放的,DECIMAL可能的最⼤取值范围和DOUBLE⼀样,但是其有效
的取值范围由M和D的值决定。如果改变M⽽固定D,则取值范围将随M的变⼤⽽变⼤
  提⽰:不论是定点还是浮点类型,如果⽤户指定的精度超出精度范围,则会四舍五⼊进⾏处理。
  FLOAT和DOUBLE在不指定精度时,默认会按照实际的精度(由计算机硬件和操作系统决定),DECIMAL如不指定精度,默认为(10,0)。
  浮点数相对于定点数的优点是在长度⼀定的情况下,浮点数能够表⽰更⼤的数据范围;它的缺点是会引起精度问题。
  提⽰:在MySQL中,定点数以字符串形式存储,在对精度要求⽐较⾼的时候(如货币,科学数据等)使⽤DECIMAL的类型⽐较好,另外两个浮点数进⾏减法和⽐较运算时也容易出问题,所以在使⽤浮点型时需要注意,并尽量避免做浮点数⽐较。
1.3 ⽇期与时间类型
  MySQL中有多种表⽰⽇期的数据类型,主要有:DATETIME、DATE、TIMESTAMP、TIME和YEAR。例如:当只记录年信息的时候,可以只是⽤YEAR类型,⽽没有必要使⽤DATE。每⼀个类型都有合法的取值范围,当指定确实不合法的值时系统将“零”值插⼊到数据库中。
⽇期与时间数据类型
sql语句获取当前系统时间类型名称⽇期格式⽇期范围存储要求
YEAR YYYY1901~21551个字节
TIME HH:MM:SS-838:59:59~838:59:593个字节
center的变形DATE YYYY-MM-DD1000-01-01~9999-12-313个字节
DATETIME YYYY-MM-DD HH:MM:SS1000-01-01 00:00:01~9999-12-31 23:59:598个字节
TIMESTAMP YYYY-MM-DD HH:MM:SS1970-01-01 00:00:01 UTC~2038-01-19 03:14:07 UTC4个字节
1.3.1 YEAR
  YEAR类型是⼀个单字节类型⽤于表⽰年,在存储时只需要1个字节。可以使⽤各种格式指定YEAR值,如下所⽰:
  (1)以4位字符串或者4位数字格式表⽰的YEAR,范围为‘1901’~‘2155’。输⼊格式为‘YYYY’或者YYYY,例如,输⼊‘2010’或2010,插⼊到数据库的值均为2010。
  (2)以2位字符串格式表⽰的YEAR,范围为‘00’到‘99’。‘00’~‘69’和‘70’~‘99’范围的值分别被转换为2000~2069和1970~1999范围的YEAR值。‘0’与‘00’的作⽤相同。插⼊超过取值范围的值将被转换为2000。
  (3)以2位数字表⽰的YEAR,范围为1~99。1~69和70~99范围的值分别被转换为2001~2069和1970~1999范围的YEAR值。注意:这⾥的0值将被转换为0000,⽽不是2000。
  (4)⾮法YEAR值将被转换为0000。
1.3.2 TIME
  TIME类型⽤于只需要时间信息的值,在存储时需要3个字节。格式为‘HH:MM:SS’。HH表⽰⼩时;MM表⽰分钟;SS表⽰秒。TIME类型的取值范围为-838:59:59~838:59:59,⼩时部分会如此⼤的原因是TIME类型不仅可以⽤于表⽰⼀天的时间(必须⼩于24⼩时),还可能是某个事件过去的时间或两个
事件之间的时间间隔(可以⼤于24⼩时,甚⾄为负)。可以使⽤各种格式指定TIME值,如下所⽰:
  (1)‘D HH:MM:SS’格式的字符串。还可以使⽤下⾯任何⼀种“⾮严格”的语法:‘HH:MM:SS’、‘HH:MM’、‘D HH:MM’、‘D HH’或‘SS’。这⾥的D表⽰⽇,可以取0~34之间的值。在插⼊数据库时,D被转换为⼩时保存,格式为“D*24+HH”。
  (2)‘HHMMSS’格式的、没有间隔符的字符串或者HHMMSS格式的数值,假定是有意义的时间。例如:‘101112’被理解为‘10:11:12’,但‘109712’是不合法的(它有⼀个没有意义的分钟部分),存储时将变为00:00:00。
  提⽰:为TIME列分配简写值时应注意:如果没有冒号,MySQL解释值时,假定最右边的两位表⽰秒。(MySQL解释TIME值为过去的时间⽽不是当天的时间)。例如,读者可能认为‘1112’和1112表⽰11:12:00(即11点过12分),但MySQL将它们解释为00:11:12(即11分12秒)。同样‘12’和12被解释为
00:00:12。相反,TIME值中如果使⽤冒号则肯定被看做当天的时间。也就是说‘11:12’表⽰11:12:00,⽽不是00:11:12。
1.3.3 DATE类型
  DATE⽤在仅需要⽇期值时,没有时间部分,在存储时需要3个字节。⽇期格式为‘YYYY-MM-DD’其中‘YYYY’表⽰年;‘MM’表⽰⽉;‘DD’表⽰⽇。在给DATE 类型的字段赋值时,可以使⽤字符串类型或者数字类型的数据插⼊,只要符合DATE的⽇期格式就⾏,如下:
  (1)以‘YYYY-MM-DD’或者‘YYYYMMDD’字符串格式表⽰的⽇期,取值范围为‘1000-01-01’~‘9999-12-31’。
  (2)以‘YY-MM-DD’或者‘YYMMDD’字符串格式表⽰的⽇期,在这⾥YY表⽰两位的年值。包含两位年值的⽇期会令⼈模糊,因为不知道世纪。MySQL使⽤以下规则解释两位年值:‘00~69’范围的年值转换为‘2000~2069’;‘70~99’范围的年值转换为‘1970~1999’。
  (3)以YY-MM-DD或者YYMMDD数字格式表⽰的⽇期,与前⾯相似,00~69范围的年值转换为2000~2069;70~99范围的年值转换为1970~1999。
  (4)使⽤CURRENT_DATE或者NOW(),插⼊当前系统⽇期。
  提⽰:MySQL允许“不严格”语法:任何标点符号都可以作⽇期部分之间的间隔符。例如:‘98-11-31’、‘98.11.31’、‘98\11\31’和‘98@11@31’是等价的,这些值也可以正确的插⼊到数据库。
1.3.4 DATETIME
  DATETIME类型⽤在需要包含⽇期和时间信息的值,在存储时需要8个字节。⽇期格式为‘YYYY-MM-DD HH:MM:SS’。再给DATETIME类型的字段赋值时,可以使⽤字符串类型或者数字类型的数据插⼊,只要符合DATETIME的⽇期格式即可,如下所⽰:
  (1)以‘YYYY-MM-DD HH:MM:SS’或者‘YYYYMMDDHHMMSS’字符串格式表⽰的值,取值范围为‘1000-01-01 00:00:00’~‘9999-12-31 23:59:59’。
  (2)以‘YY-MM-DD HH:MM:SS’或者‘YYMMDDHHMMSS’字符串格式表⽰的⽇期,在这⾥YY表⽰两位的年值,与前⾯相同。
  (3)以YYYYMMDDHHMMSS或者YYMMDDHHMMSS数字格式表⽰的⽇期和时间,也能正常插⼊数据库中。
1.3.5 TIMESTAMP
  TIMESTAMP的显⽰格式与DATETIME相同,显⽰宽度固定在19个字符,⽇期格式为YYYY-MM-DD HH:MM:SS,在存储时需要4个字节。但是TIMESTAMP列的取值范围⼩于DATETIME的取值范围,为‘1970-01-01 00:00:01’ UTC~‘2038-01-19 03:14:07’ UTC,其中,UTC(Coordinated Universal Time),为世界标准时间,因此在插⼊数据时,要保证在合法的取值范围内。
1.4 ⽂本字符串类型
  字符串类型⽤来存储字符串数据,除了可以存储字符串数据之外,还可以存储其他数据,⽐如图⽚和声⾳的⼆进制数据。MySQL⽀持两类字符串类型数据:⽂本字符串和⼆进制字符串。⽂本字符串可以进⾏区分或者不区分⼤⼩写的串⽐较,另外,还可以进⾏模式匹配查。MySQL中⽂本字符串类型指CHAR、VARCHAR、TEXT、EMUN和SET。
MySQL中⽂本字符串数据类型
类型名称说明存储需求
CHAR(M)固定长度⾮⼆进制字符串M字节,1<=M<=255
VARCHAR(M)变长⾮⼆进制字符串L+1字节,在此L<=M和1<=M<=255
TINYTEXT⾮常⼩的⾮⼆进制字符串L+1字节,在此L<2^8
TEXT⼩的⾮⼆进制字符串L+2字节,在此L<2^16
DEDIUMTEXT中等⼤⼩的⾮⼆进制字符串L+3字节,在此L<2^24
LONGTEXT⼤的⾮⼆进制字符串L+4字节,在此L<2^32
ENUM枚举类型,只能有⼀个枚举字符串值1或2个字节,取决于枚举值的数⽬(最⼤值65535)
SET⼀个设置,字符串对象可以有零个或多个SET成员1,2,3,4或8个字节,取决于集合成员的数量(最多64个成员)
  VARCHAR和TEXT类型是变长类型,对于其存储需求取决于列值的实际长度,⽽不是取决于类型的最⼤可能尺⼨。例如,⼀个VARCHAR(10)列能保存最⼤长度为10个字符的⼀个字符串,实际的存储需要是字符串的长度L,加上1个字节以记录字符串的长度。
1.4.1 CHAR和VARCHAR类型
  CHAR(M)为固定长度字符串,在定义时指定字符串列长。当保存时在右侧填充空格以达到指定的长度。M表⽰列长度,M的范围是
numerical analysis
0~255个字符。
  VARCHAR(M)是长度可变的字符串,M表⽰最⼤列长度。M的取值范围是0~65525。VARCHAR的最⼤实际长度由最长的⾏的⼤⼩和使⽤的字符集确定,⽽实际占⽤的空间为字符串的实际长度加1。
1.4.2 TEXT类型
  TEXT列保存⾮⼆进制字符串,如⽂章内容、评论等。当保存或查询TEXT列的值时,不删除尾部空格。TEXT类型分为4种:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。不同的TEXT类型的存储空间和数据长度不同。
1.4.3 ENUM类型
  ENUM是⼀个字符串对象,其值为表创建时在列规定中枚举的⼀列值。语法格式如下:
字段名 ENUM('值1','值2',......,'值n')
  ENUM类型的字段在取值时,只能在定义的枚举列表中取,⽽且⼀次只能取⼀个。如果创建的成员中有空格,其尾部的空格将⾃动被删除。ENUM值在内部⽤整数表⽰,每个枚举值都有⼀个索引值:列表值所允许的成员值从1开始编号,MySQL存储的就是这个索引编号。枚举最多可以有65535个元素。
  例如定义ENUM类型列('first', 'second', 'third'),该列可以取的值和每个值的索引如下所⽰:
ENUM类型的
取值范围
值索引
NULL NULL
''0
first1
second2
third3
  查看索引值的语句:
SELECT enu,enu+0FROM tbname
  提⽰:ENUM列总有⼀个默认值。如果将ENUM列声明为NULL,NULL值则为该列的⼀个有效值,并且默认值为NULL。如果ENUM列被声明为NOT NULL,其默认值为允许的值列表的第⼀个元素。
1.4.4 SET类型
  SET是⼀个字符串对象,可以有零或多个值,SET列最多可以有64个成员,其值为表创建时规定的⼀列值。指定包括多个SET成员的SET列值时,各成员之间⽤逗号(,)间隔开。语法格式如下:
SET('值1','值2',......,'值n')
  与ENUM类型相同,SET值在内部⽤整数表⽰,列表中每⼀个值都有⼀个索引编号。当创建表时,SET成员值的尾部空格将⾃动被删除。但与ENUM类型不同的是,ENUM类型字段只能从定义的列值中选择⼀个值插⼊,⽽SET类型的列可以从定义的列值中选择多个字符的联合。
  如果插⼊SET字段中列值有重复,则MySQL⾃动删除重复的值;插⼊SET字段的值的顺序并不重要,MySQL会在存⼊数据库时,按照定义的顺序显⽰;如果插⼊了不正确的值,默认情况下,MySQL将忽略这些值,并给出警告。
1.5 ⼆进制字符串类型
mysql语句分类  MySQL⼆进制数据类型有:BIT、BINARY、VARBINARY、TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB。
MySQL中的⼆进制字符串类型
类型名称说明存储需求
BIN(M)位字段类型⼤约(M+7)/8个字节
BINARY(M)固定长度⼆进制字符串M个字节
VARBINARY(M)可变长度⼆进制字符串M+1个字节
TINYBLOB(M)⾮常⼩的BLOB L+1字节,在此L<2^8
BLOB(M)⼩BLOB L+2字节,在此L<2^16
MEDIUMBLOB(M)中等⼤⼩的BLOB L+3字节,在此L<2^24
LONGBLOB(M)⾮常⼤的BLOB L+4字节,在此L<2^32
1.5.1 BIT类型
  BIT类型是位字段类型。M表⽰每个值的位数,范围为1~64。如果M被省略,默认为1。如果为BIT(M)分配的值的长度⼩于M位,在值的左边⽤0填充。例如,为BIT(6)列分配⼀个值b'101',其效果与分配b'000101'相同。BIT数据类型⽤来保存位字段值,例如,以⼆进制形式保存数据13,13的⼆进制形式为1101,在这⾥需要位数⾄少为4位的BIT类型,即可定义列类型为BIT(4)。⼤于⼆进制的数据是不能插⼊BIT(4)类型的字段中的。
1.5.2 BINARY和VARBINARY类型
  BINARY和VARBINARY类型类似于CHAR和VARCHAR,不同的是它们包含的是⼆进制字节字符串。
  BINARY类型的长度是固定的,指定长度之后,不⾜最⼤长度的,将在它们右边补充'\0',补齐以达到指定长度。不管存储的内容是否达到指定的长度,其存储空间均为指定的值M。
  VARBINARY类型的长度是可变的,指定好长度之后,其长度可以在0到最⼤值之间。例如:指定列数据类型为VARBINARY(20),如果插⼊的值的长度只有10,则实际存储空间为10+1,即实际占⽤的空间为字符串的实际长度+1。
1.5.3 BLOB类型
  BLOB是⼀个⼆进制⼤对象,⽤来存储可变数量的数据。BLOB类型分为4种:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB,它们可容纳值的最⼤长度不同。
BLOB类型的存储范围
数据类型存储范围
TINYBLOB最⼤长度为255(2^8-1)B
BLOB最⼤长度为65535(2^16-1)B
MEDIUMBLOB最⼤长度为16777215(2^24-1)B
LONGBLOB最⼤长度为4294967295(2^32-1)B
  BLOB列存储的是⼆进制字符串(字节字符串);TEXT列存储的是⾮⼆进制字符串(字符字符串)。BLOB列没有字符集,并且排序和⽐较基于列值字节的数值;TEXT列有⼀个字符集,并且根据字符集对值进⾏排序和⽐较。
⼆、如何选择数据类型
  MySQL提供了⼤量的数据类型,为了优化存储,提⾼数据库性能,在任何情况下均应使⽤最精确的类型。即在所有可以表⽰该列值的类型中,该类型使⽤的存储最少。
2.1 整数和浮点数
  如果不需要⼩数部分,则使⽤整数来保存数据;如果需要表⽰⼩数部分,则使⽤浮点数类型。对于浮点数据列,存⼊的数值会对该列定义的⼩数位进⾏四舍五⼊。例如,如果列的值的范围为1~99999,若使⽤整数,则MEDIUMINT UNSIGNED是最好的类型;若需要存储⼩数,则使⽤FLOAT类型。
  浮点类型包括FLOAT和DOUBLE类型。DOUBLE类型精度⽐FLOAT⾼,因此,如要求存储精度较⾼时,应选择DOUBLE类型。
2.2 浮点数和定点数
  浮点数FLOAT、DOUBLE相对于定点数DECIMAL的优势是:在长度⼀定的情况下,浮点数能表⽰更⼤的数据范围,但是由于浮点数容易产⽣误差,因此对精确度要求⽐较⾼时见识使⽤DECIMAL来存储。DECIMAL在MySQL中是以字符串存储的,⽤于定义货币等对精度要求较⾼的数据。在数据迁移中,FLOAT(M,D)是⾮标准SQL定义,数据库迁移可能会出现问题,最好不要这样使⽤。另外两个浮点数进⾏减法和⽐较时也容易出现问题,因此在进⾏计算的时候,⼀定要⼩⼼。如果进⾏数值⽐较,最好使⽤DECIMAL类型。
2.3 ⽇期与时间类型
  MySQL对于不同种类的⽇期和时间有很多的数据类型,⽐如YEAR和TIME。如果只需要记录年份,则使⽤YEAR类型即可;如果只记录时间,只需要使⽤TIME类型。
  如果同时需要记录⽇期和时间,则可以使⽤TIMESTAMP或者DATETIME类型。由于TIMESTAMP列的取值范围⼩于DATETIME的取值范围,因此存储范围较⼤的⽇期最好使⽤DATETIME。
  TIMESTAMP也有⼀个DATETIME不具备的属性。默认的情况下,当插⼊⼀条记录但并没有指定TIMESTAMP这个列值时,MySQL会把TIMESTAMP列设为当前的时间。因此当需要插⼊记录同时当前时间时,使⽤TIMESTAMP是⽅便的,另外TIMESTAMP在空间上⽐DATETIME更有效。
2.4 CHAR和VARCHAR之间的特点与选择
  CHAR和VARCHAR的区别如下:
  (1)CHAR是固定长度字符,CARCHAR是可变长度字符;
  (2)CHAR会⾃动删除插⼊数据的尾部空格,VARCHAR不会删除尾部空格。
  CHAR是固定长度,所以它的处理速度⽐VARCHAR要快,但是它的缺点就是浪费存储空间。所以对存储不⼤,但在速度上有要求的可以使⽤CHAR类型,反之可以使⽤VARCHAR类型来实现。
  存储引擎对于选择CHAR和CARCHAR的影响:
  (1)对于MyISAM存储引擎,最好使⽤固定长度的数据列代替可变长度的数据列。这样可以使整个表静态化,从⽽使数据检索更快,⽤空间换时间。
  (2)对于InnoDB存储引擎,使⽤可变长度的数据列,因为InnoDB数据表的存储格式不分固定长度和可变长度,因此使⽤CHAR不⼀定⽐使⽤VARCHAR更好,但由于VARCHAR是按照实际的长度存储,⽐较节省空间,所以对磁盘I/O和数据存储总量⽐较好。
2.5 ENUM和SET
  ENUM只能取单值,它的数据列表是⼀个枚举集合。它的合法取值列表最多允许65535个成员。因此,在需要从多个值中选取⼀个时,可以使⽤ENUM。
  SET可取多值。它的合法取值列表最多允许有64个成员。空字符串也是⼀个合法的SET值。在需要取多个值的时候,适合使⽤SET类型。
  ENUM和SET的值都是以字符串形式出现的,但在内部,MySQL以数值形式存储它们。
2.6 BLOB和TEXT
  BLOB是⼆进制字符串,TEXT是⾮⼆进制字符串,两者均可存放⼤容量的信息。BLOB主要存储图⽚、⾳频信息等,⽽TEXT只能存储纯⽂本⽂件。
三、常见运算符介绍
  运算符连接表达式中各个操作数,其作⽤是⽤来指明对操作数所进⾏的运算。运⽤运算符可以更加灵活的使⽤表中的数据,常见的运算符类型有:算术运算符,⽐较运算符,逻辑运算符,位运算符。
3.1 运算符概述

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。