MySQL基础01-数据类型

一、整数类型

每个整型类型可以指定一个最小显示宽度(注意:这个宽度并不表示存储的值有多大)

类型 存储空间(N) 取值范围:-2(N-1)到 2(N-1)-1
TINYINT 8 -128……127
SMALLINT 16 -32768……32767
MEDIUMINT 24 -8388608……8388607
INT 32 -2147483648……2147483647
BIGINT 64 (自己算... ...)

注:如果有指定UNSIGNED属性,则存取范围可以提升一倍,
即:-2N到 2N-1

基本格式:

INT[(M)] [UNSIGNED] [ZEROFILL]

① M:指定显示宽度(默认是M=10),以实际的取值范围为准,值超过显示宽度,显示宽度自动增加
② unsigned:无符号的,表示只允许正数,所以取值范围取绝对值且最大值*2
③ zerofill: 填充0(如果声明了zerofill,该列会自动设为unsigned)

二、实数类型

1、定点小数:decimal

基本格式:

DEC[(M[,D])] [UNSIGNED] [ZEROFILL]

① M:精度,(整数位数+小数位数)不包含小数点的数字总位数(1--30),不指定默认为10
② D:小数位数,如果不指定,默认为0

注: 若位数不够,小数末尾补零;若位数超预算,则报错。

2、浮点数:float与double

基本格式:

float[(length) | (<display width>,<scale>)]
double[(precision) | (<display width>,<scale>)]

两者区别在于值所保留的存储空间数量不同

注:由于对一个浮点数字来说,可用的存储空间有限,如果一个数字非常大或非常小,将存储这个数字的近似值而不是实际值。

使用方法:

① 使用一个参数来指定浮点类型
length/precision:在一个浮点数据类型中可以指定长度,来确定具体的浮点类型。
0~24:单精度float,从第7位有效位,进行四舍五入存储
25~30:双精度double,从第16位有效位,进行四舍五入存储
如:

mysql> create table t3(id float(8));
//m=8,说明是单精度,存储6位的近似值(第7位四舍五入,后面为0)
mysql> insert into t3 values(123);
mysql> insert into t3 values(1234567);
mysql> insert into t3 values(123456789);
mysql> insert into t3 values(123456789.123456789);

mysql> select * from t3;
+-----------+
| id        |
+-----------+
| 123       |
| 1234570   |
| 123457000 |
| 123457000 |
+-----------+

② 使用两个参数来指定浮点类型
单精度float(m,d):m表示精度(0~24),d表示小数位数
双精度double(m,d):m表示精度(25~30),d表示小数位数
注意:整数位(m-d)不够没关系,超出报错;小数位(d)不够补零,超出四舍五入。

三、字符串

类型 描述
char(n) 固定长度,最多255个字符。char非常适合用于存储密码的MD5值
varchar(n) 可变长度,最多65535个字符。varchar需要使用1或2个额外字节记录字符串长度:如果列的最大长度小于或等于255字节,则使用1个字节表示,否则使用2个字节。
TEXT 包括TINYTEXT、SMALLTEXT(TEXT)、MEDIUMTEXT、LONGTEXT
BLOB 包括TINYBLOB、SMALLBLOB(BLOB)、MEDIUMBLOB、LONGBLOB,二进制类型。BLOB 可以储存图片。

1、char和varchar
区别:
① char(n) 若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空格,varchar不限于此。
② char(n) 固定长度,char(4)不管是存入几个字符,都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入3个字符将占用4个字节。
③ char类型的字符串检索速度要比varchar类型的快。
④ 对于经常更变的数据,char比varchar更好,char不容易产生碎片。
相同:
① 如果存储内容走出指定长度,都会被截断。

2、varchar和text的区别:
① varchar可指定n,text不能指定,内部存储varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),text是实际字符数+2个字节。
② text类型不能有默认值。
③ varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作用。
④ char和varchar可以有默认值,text不能指定默认值。

注:尽量避免使用BLOB/TEXT类型,查询会使用临时表,导致严重的性能开销。

四、枚举

枚举可以把一些不重复的字符串存储成一个预定的集合。MySQL在存储枚举时非常紧凑,会根据列表值的数量压缩到一个或者两个字节中。MySQL在内部会将每个值在列表中的位置保存为整数,并且在表的.frm文件中保存“数字 - 字符串”映射关系的“查找表”。

注:尽量避免使用数据作为ENUM枚举的常量,易混乱。

五、时间和日期

类型 描述
DATETIME 表示时间范围是1001年到9999年,精度为秒。占用8个字节。
TIMESTAMP 占用4个字节,表示时间范围从1970年到2038年。使用该类型时一定要注意时区问题。

六、位

位主要是用来存放二进制数,select查询默认显示10进制,可以使用bin()、hex()函数来进行查询。

bin()---显示二进制格式
hex()---显示十六进制格式

如:

mysql> create table t(id bit(4));

mysql> insert into t values(2);
mysql> insert into t values(13);

mysql> select bin(id),hex(id) from t;
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 10      | 2       |
| 1101    | D       |
+---------+---------+ 

参考

《高性能MySQL》 [美]Baron Scbwartz, Peter Zaitsev, Vadim Tkacbenko 著

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 非常开心!因为宝贝,也因为自己。 小平作为学生代表,在三千多人面前发言,镇定自若,很有大将风度。其实对于小平来说,...
    小欧_Sally阅读 296评论 0 0
  • 不烦不燥,我们随遇而安,不卑不吭,我们挥斥方遒,从遇见你开始,我就在感恩上苍,因为遇见你,我开始明白什么叫做温文尔...
    般若Prajna阅读 332评论 0 0
  • 看着身边人来来往往,每个人都有自己的故事,故事太多,来不及记忆,就慢慢的流淌到岁月长河里,无人问津。 小a是一个肤...
    kk卡卡ka阅读 325评论 0 0
  • 《爱自己,你在哪一个层面?》 爱自己的第一个层面: 吃好、喝好、睡好、冷暖照顾好,健康长寿; 爱自己的第二个层面:...
    欣颍阅读 112评论 0 0
  • 早上五点,听着熟悉的闹铃声,我没有一下子起来,而是任由音乐漫过内心,陷入了深深地思考。音乐来自国王的演讲插曲,依稀...
    Vampire丶黑狐阅读 196评论 1 1