MySQL 数据库存储类型

MySQL 数据库存储类型,第1张

数值类型包含: int tinyint bigint float decimal

int 大整型(占 4 个字节的存储空间)

tinyint 微小整型(占 1 个字节的存储空间)

bigint 极大整型(占 8 个字节的存储空间)

float 占4个字节,最多显示7个有效位。常用于成绩。

float(5,2)取值范围:

decimal 最多可以显示 28 个有效位

存储空间计算:整数部分和小数部分分开存储,将 9 的倍数包装成 4 个字节,余数占用的字节数如下:

decimal 的整数位和小数位模9的余数和字节对照表

例如: decimal(19,9)

整数部分:

小数部分:

char 定长:当列中存储的字符串达不到最大长度时,使用空格进行补足。

varchar 变长

char 浪费存储空间,但性能高。 varchar 节约存储空间,但存储性能低。

text / longtext(4G)

数值类型宽度为显示宽度,和占用存储空间大小无关;字符类型的宽度,超过则无法存储:

对于枚举类型的字段,字段值只能在列举的范围内选择。

日期时间类型: date time datetime timestamp

date日期:

time时间:

datetime日期时间:

timestamp 日期时间:

日期时间函数: NOW() CURDATE() CURTIME()

NOW() 返回服务器当前的时间:

CURDATE() 返回当前日期:

CURTIME() 返回当前时间:

插入日期时间:

语法格式:

示例:

查询1天以内的记录:

查询2年前至今年的记录:

InnoDB的数据文件本身就是主索引文件。而MyISAM的主索引和数据是分开的。辅助索引data域存储相应记录主键的值而不是地址。

innoDB是聚簇索引,数据挂在逐渐索引之下。

是 MySQL 默认的事务型存储引擎, 只有在需要它不支持的特性时,才考虑使用其它存储引擎

实现了四个标准的隔离级别,默认级别是可重复读(REPEATABLE READ)。在可重复读隔离级别下,通过多版本并发控制(MVCC)+ 间隙锁(Next-Key Locking)防止幻影读。

主索引是聚簇索引,在索引中保存了数据,从而避免直接读取磁盘,因此对查询性能有很大的提升。

内部做了很多优化,包括从磁盘读取数据时采用的可预测性读、能够加快读 *** 作并且自动创建的自适应哈希索引、能够加速插入 *** 作的插入缓冲区等。

支持真正的在线热备份。其它存储引擎不支持在线热备份,要获取一致性视图需要停止对所有表的写入,而在读写混合场景中,停止写入可能也意味着停止读取。

以B+树作为索引结构,叶节点的数据域存放数据记录的地址。主索引和辅助索引在结构上没有区别,只是主索引要求key唯一,而辅助索引的key可以重复。

MyISAM中索引检索的算法为首先按照B+Tree搜索算法搜索索引,如果指定的Key存在,则取出其data域的值,然后以data域的值为地址,读取相应数据记录。

设计简单,数据以紧密格式存储。对于只读数据,或者表比较小、可以容忍修复的 *** 作,则依然可以使用它。

提供了大量的特性,包括压缩表、空间数据索引等。

不支持事务

不支持行级锁,只能对整张表加锁,读取时会对需要读到的所有表加共享锁,写入时则对表加排它锁。但在表有读取 *** 作的同时,也可以往表中插入新的记录,这被称为并发插入(CONCURRENT INSERT)。

可以手工或者自动执行检查和修复 *** 作,但是和事务恢复以及崩溃恢复不同,可能导致一些数据丢失,而且修复 *** 作是非常慢的。

如果指定了 DELAY_KEY_WRITE 选项,在每次修改执行完成时,不会立即将修改的索引数据写入磁盘,而是会写到内存中的键缓冲区,只有在清理键缓冲区或者关闭表的时候才会将对应的索引块写入磁盘。这种方式可以极大地提升写入性能,但是在数据库或者主机崩溃时会造成索引损坏,需要执行修复 *** 作。

Bit称为位数据类型,其数据有两种取值:0和1,长度为1位。在输入0以外的其他值时,系统均把它们当1看待。这种数据类型常作为逻辑变量使用,用来表示真、假或是、否等二值选择。

补充:

1、MySQL 是一个关系型数据库,由瑞典 MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

2、MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的 SQL 语言是用于访问数据库的最常用标准化语言。

3、MySQL 软件采用了双授权政策(本词条"授权政策"),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

4、由于其社区版的性能卓越,搭配 PHP ,Linux和 Apache 可组成良好的开发环境,经过多年的web技术发展,在业内被广泛使用的一种web服务器解决方案之一,称之为LAMP。


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

原文地址: http://outofmemory.cn/zaji/7257369.html

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

发表评论

登录后才能评论

评论列表(0条)

保存