数据定义语言:数据类型 数据类型:数字 类型 大小 说明 TINYINT 1字节 ^1 小整数 SMALLINT 2字节 普通整数 MEDIUMINT 3字节 普通整数 INT 4字节 较大整数 BIGINT...temp CREATE TABLE temp( id INT UNSIGNED PRIMARY KEY, num DECIMAL(20,10) ) 0.2 ----> 0.2000000000 数据类型...不固定长度字符串 TEXT 1 - 65535 字符 不确定长度字符串 MEDIUMTEXT 1 - 1 千 6 百万字符 不确定长度字符串 LONGTEXT 1 - 42 亿字符 不确定长度字符串 数据类型
---- Pre MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的,我们这里主要讨论MyISAM和InnoDB两个存储引擎的索引实现方式。...我这个是8.0的MYSQL, 5.7版本 不是sdi结尾的文件,而是frm (framework) 可以看到MyISAM存储引擎的索引文件 MYI 和数据文件 MYD 是分离的(非聚集) 这就是非聚簇索引的含义...InnoDB也使用B+Tree作为索引结构,但具体实现方式却与MyISAM 不同。 ---- 索引原理图 ?...---- 第二个与MyISAM索引的不同是InnoDB的辅助索引data域存储相应记录主键的值而不是地址。换句话说,InnoDB的所有辅助索引都引用主键作为data域 ?...则MySQL自动为InnoDB表生成一个隐含字段作为主键,这个字段长度为6个字节,类型为长整形。
MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数。...许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者用零填补。...TEXT 和 BLOB 类型 对于字段长度要求超过 255 个的情况下,MySQL 提供了 TEXT 和 BLOB 两种类型。根据存储数据的大小,它们都有不同的子类型。...日期和时间类型 在处理日期和时间类型的值时,MySQL 带有 5 个不同的数据类型可供选择。它们可以被分成简单的日期、时间类型,和混合日期、时间类型。...虽然这些类型在技术上是字符串类型,但是可以被视为不同的数据类型。一个 ENUM 类型只允许从一个集合中取得一个值;而 SET 类型允许从一个集合中取得任意多个值。
MongoDB的默认数据库为”db”,该数据库存储在data目录中。 MongoDB的单个实例可以容纳多个独立的数据库,每一个都有自己的集合和权限,不同的数据库也放置在不同的文件中。...一个简单的文档例子如下: {"hand":"hello","foot":3} 文档中的键是字符串,文档中的值可以是多种不同的数据类型,甚至可以是一个完整的内嵌文档。...数据类型 例子 描述 String { “x” : “foot” } 字符串。存储数据常用的数据类型。在 MongoDB 中,UTF-8 编码的字符串才是合法的。...该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用特殊符号类型的语言。 Date { “x” : new Date() } 日期时间。用 UNIX 时间格式来存储当前日期或时间。...下面的文档中things这个键的值是一个数组 { “things” : [ “foot” , 3.14 ] } 此例表述数组可包含不同数据类型的元素。 数组也可嵌套数组。
该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:MySQL中TEXT数据类型的最大长度 在MySQL中,TEXT数据类型用于存储较大的文本数据...以下是MySQL中不同TEXT类型的最大长度: TINYTEXT:最大长度为255个字符(2^8-1)。 TEXT:最大长度为65,535个字符(2^16-1)。...对于非拉丁字符集(如UTF-8),一个字符可能占据多个字节的存储空间。 此外,MySQL还提供了BLOB数据类型,用于存储二进制大对象。...与TEXT类型类似,BLOB类型也有不同的子类型(TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB),其最大长度与对应的TEXT类型相同。...当使用TEXT或BLOB类型存储较大的数据时,可能会影响性能和存储空间的使用。在设计数据库时,应根据实际需求和性能考虑选择合适的数据类型和存储方案。
MYSQL 在建立之初,表的格式就有好几种,与其他的数据库不同,你从未听说 ORACLE ,SQL SERVER , PG 对于表的存储格式有不同,而MYSQL 在建表的时候有一个地方对于存储的表的格式有不一样的设定...ROW FORMAT 是指标中的行在磁盘中的物理存储的格式,一般我们在MYSQL8上建立的表如果你不指定row_format的格式的情况下,默认我们的表存储的格式是 DYNAMIC ....今天要谈这个问题,主要思路来自于,公司存储在MYSQL上的数据一直都有需要归档的需求,而数据归档临时的数据也是要存储在MYSQL上的,那么降低数据存储的空间,对于数据存储的空间的消耗是有利的。...那么实际上我们还可以针对字符型的字段进行一个测试,看看那种的方式对比存储INT 有什么不同。...综上所述:MYSQL 不同的ROW_FORMAT 格式对于数据占用的空间除了 compressed 格式以外,在空间的相差并不大。
在设计数据库时,了解不同数据类型的存储机制是非常重要的,它不仅影响到数据的存储效率,还可能影响到数据库的性能。...MySQL数据库中的数据类型大致可以分为两类:动态分配存储空间的类型和固定分配存储空间的类型。在这篇文章中,我们将详细介绍这两类数据类型及其特点。 1....以下是MySQL中几种常见的动态分配存储空间的数据类型: 1.1 BLOB和TEXT类型 BLOB和TEXT类型是用于存储二进制数据和文本数据的数据类型,它们的存储空间是动态分配的。...总结 了解MySQL中不同数据类型的存储机制,可以帮助我们更好地设计数据库,优化数据库的性能和存储效率。...在设计数据库时,应根据实际需求和应用场景,合理选择和使用不同的数据类型。
表存储格式&数据类型 Hive表的存储格式 Hive支持的表类型,或者称为存储格式有:TextFile、SequenceFile、RCFile、ORC、Parquet、AVRO。...在存储时,首先会按照行数进行切分,切分为不同的数据块进行存储,也就是行存储;在每一个数据块中,存储时使用的又是列式存储,将表的每一列数据存放在一起。...数据类型 基本数据类型 数值型 Hive数值型包含整数、浮点数两种。...复杂数据类型 Hive支持复杂数据类型array、map、struct、union。 数据类型比较 对于这些数据类型,仅需要在使用时进行参考即可。...其中JDBC与Hive数据类型的对照关系如下图所示: 接下来是Orcale与Hive的数据类型对照: 除此之外,DB2也是常见的数据库,DB2与Hive的数据类型对照如下: 对于这些数据类型
数据类型分类 对于数据类型分类,这里简单分为数值类型(如BIT,BOOL,INT),文本、二进制类型(如CHAR,VARCHAR),时间日期(DATE),String类型(如ENUM类型),这里简单了解一下即可...数值类型 不同的类型所占字节数是不一样的。...of range value for column 'num' at row 1 mysql> 用tinyint unsigned数据类型创建表t2: mysql> create table if not...decimal decimal也是mysql中的浮点数类型,float存储数据时,小数比较大,或者小数位点比较多存储的就不太准确了,这与浮点数存储规则有关(mysql中的float浮点数精度为是7)。...的字符与C/C++语言不同,mysql的字符代表的是符号,所以能够插入成功!
mysql 数据类型 MySQL数据类型 含义(有符号) tinyint(m) 1个字节 范围(-128~127) smallint(m) 2个字节 范围(-32768~32767) mediumint...浮点型(float和double) MySQL数据类型 含义 float(m,d) 单精度浮点型 8位精度(4字节) m总个数,d小数位 double(m,d) 双精度浮点型 16位精度(8字节) m总个数... 字符串(char,varchar,_text) MySQL数据类型 含义 char(n) 固定长度,最多255个字符 varchar(n) 固定长度,最多65535个字符 tinytext...二进制数据(_Blob) 1.BLOB和text存储方式不同,TEXT以文本方式存储,英文存储区分大小写,而Blob是以二进制方式存储,不分大小写。 2._BLOB存储的数据只能整体读出。...数据类型的属性 MySQL关键字 含义 NULL 数据列可包含NULL值 NOT NULL 数据列不允许包含NULL值 DEFAULT 默认值 PRIMARY KEY 主键 AUTO_INCREMENT
数据类型分类 简单看一下数据可常见类型: 数值类型 tinyint类型 创建一个表,表中内容是tinyint型有符号: mysql> create table if not exists t1 (...总结: 如果插入的数据超过MySQL数据类型的范围,那么MySQL就不让你插入,直接拦截,不让做对应的操作。...如果已经有数据被成功插入到MySQL中,那么插入的时候一定是合法的。 因此,MySQL中,一般而言,数据类型本身也是一种约束。...字符串类型 char 语法: char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255。...set:集合,“多选”类型; set('选项值1','选项值2','选项值3', ...); 该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是
MySQL 存储过程(了解) 1 什么是存储过程 MySQL 5.0 版本开始支持存储过程 存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据 库对象。...存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过 指定存储过程的名字并给定参数(需要时)来调用执行。 简单理解: 存储过程其实就是一堆 SQL 语句的合并。...,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区) 缺点: 在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一...goods; END $$ 3) 调用存储过程 语法格式 call 存储过程名 -- 调用存储过程 查询goods表所有数据 call goods_proc; 方式2 1) IN 输入参数:表示调用者向存储过程传入值...# 删除 id为2的商品 CALL goods_proc02(2) 方式3 1) 变量赋值 SET @变量名=值 2) OUT 输出参数:表示存储过程向调用者传出值 OUT 变量名 数据类型 3) 创建存储过程
---- 数值类型 MySQL支持所有标准SQL数值数据类型。...BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。 作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。...下面的表显示了需要的每个整数类型的存储和范围。...它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。...它们只是可容纳值的最大长度不同。 有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求。
数值类型 MySQL支持所有标准SQL数值数据类型。...BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。 作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。...下面的表显示了需要的每个整数类型的存储和范围。...它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。...它们只是可容纳值的最大长度不同。 有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求。
数据类型实际上也是对数据的一种约束。...一.数据类型分类 二.数值类型 三.tinyint类型 数值越界测试: mysql> create table tt1(num tinyint); Query OK, 0 rows affected...当然,不同的sql版本在浮点数的规则已经精度会不同,但是我们应该以实验为准,来应对不同版本所对应的规则。...---- 应用场景 date和datetime和时间戳不同,不会随着数据更新而更改,但能够记录一些特殊的日期,比如入职年份,生日等关键时间点。...;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,… 最多64个。
MySQL 数据类型 MySQL中定义数据字段的类型对你数据库的优化是非常重要的。 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。...---- 数值类型 MySQL支持所有标准SQL数值数据类型。...CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。...它们区别在于可容纳存储范围不同。 有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。...对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。
MySQL之数据类型 MySQL常见的数据类型有数值、日期和时间、字符串 数值 整数类型(精确值) Integer Types (Exact Value) - INTEGER, INT, SMALLINT...5位数字,精确到小数点后2位; 存储范围: -999.99 ~ 999.99 NUMERIC就是NUMERIC 说明:精度是几,小数点+整数位不能超过前面的精度。...MySQL进行舍入时存储的值,所以如果你插入999.00009成浮(7,4)柱,近似的结果是999.0001 If M and D are omitted, values are stored to the...limits permitted by the hardware. double 存储 8bytes 时间和日期 DATE:日期 'YYYY-MM-DD'.... and '838:59:59';无效的的时间值会被转换成'00:00:00' YEAR: range 1901 to 2155, or 0000 注意:YEAR(4) and YEAR(2)不同之处在于显示不同
delimiter 指定SQL语句的结束符 存储过程中的变量 在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量; 一、系统变量 系统变量是MySQL服务器系统自身提供的...一个简单的案例,判断分数在不同的区间,然后输出不同的值; create procedure p3() BEGIN declare score int default 59; declare result...([ IN/OUT/INOUT 参数名 参数类型 ]) BEGIN -- SQL END; 将上面的案例进行简单改造,通过外面传入的参数,判断分数在不同的区间,从而返回不同的结果; create...循环语句在编程中经常被用到,常用于对批量的数据进行循环处理,在mysql的存储过程中,也提供了几种常用的循环语句,包括:while循环,repeat循环,和loop循环; 1、while循环语句 while...,使用存储过程也可以完成,但是存储函数的局限在于,函数必须要有返回结果; 八、存储过程中游标的使用 游标(CURSOR)是用来存储查询结果集的数据类型 , 在存储过程和函数中可以使用游标对结果集进行循环的处理
一、数据类型分类 ---- 二、INT类型 1.tinyint类型 (1)有符号 tinyint类型的数据范围为-128~127 我们创建好一张表,其中成员age的类型为tinyint。...当我们插入一个超过范围的数据时,我们会发现会插入失败,由此我们可以得到一个结论:我们成功插入到MYSQL中的数据,一定是合法的。这样能够约束程序员尽可能的插入正确的数据。...(2)无符号 在MySQL中,整型可以指定是有符号的和无符号的,默认是有符号的。...,单位为字符,最大长度值可以为255 char在mysql中长度指的是字符的长度,不论是字母、数字还是中文。...例如:我们设定为10个字符的长度, 我们插入3个字符,那么varchar实际也只开辟3个字符的大小来存储。
MySQL数据类型优化 作者的故事 原本觉得mysql数据类型是非常简单并十分基础的知识,认为自己掌握的差不多了。但经过上一次的面试,才发现自己掌握的并不牢固,很多细节和原理并不知道。...后来翻阅了《高性能mysql》这本书,仔细阅读了第四章Schema与数据类型优化。因此,写这篇文章记录和总结下,并加深理解。...选择优化的数据类型 不管存储哪几种类型,以下几个简单的原则都有助于做出更好的选择 更小的通常更好 简单就好 尽量避免null 整数类型 数据类型 存储空间 TINYINT 8位 SMALLINT 16位...有一种情况例外,如果MySQL表使用ROW_FORMAT=FIXED创建的话,每一行都会定长存储。...总结 本篇文章主要是介绍MySQL常用的数据类型,如有错误或者不准确的地方,欢迎交流。
领取专属 10元无门槛券
手把手带您无忧上云