首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL基础『数据类型』

testINT; 注意: MySQL 创建无符号类型,是类型之后加上 unsigned 括号的数字通常用于指定显示宽度,并不表示存储范围 向插入一组合法的数据 mysql> insert into...4.1.CHAR char C/C++ 称为字符类型,大小为 1 字节 MySQL 则是叫做 固定长度字符串,也就是说 char 可以存储字符串(前提是长度足够) CHAR(L) 创建一张...; 向插入字符串 注: MySQL使用 ‘ ' 或者 " " 括起来的为字符串 mysql> insert into testChar values ('a'), ('bb'), ('战'),...testVarchar; 注意: 我这里能修改成功是因为当前的 testVarchar 只有一个字符,数据字段也是需要占用空间的,当字段过多时,是无法修改 varchar 为最大容量的...如果实际使用场景多次涉及 varchar 的边界,可以改用 text,这是一个专门用来存储文本数据的类型,比如我当前编写的博客,就是通过该类型存储的 4.3.如何使用 char 与 varchar 的区别如下

17910

MySQL 简单查询语句执行过程分析(五)发送数据给客户端

示例 e1 字段各选项及其对应的整数值如下图: 假设存储引擎返回的 e1 字段整数值为 7,发送数据之前,会找到 7 对应选项的内容成都,占用字节数为 2(字数)* 3(utf8 一个汉字占用字节数...2.5 set 类型 set 类型字段存储引擎也是以整数存储,发送数据之前,通过整数找到一个或多个对应选项的内容作为字段内容,如果有多个选项,字段内容多个选项的内容之间用逗号分隔。...bit 类型字段 InnoDB 是以 C/C++ 的 char 类型存储的,实际就是按字节存储,1 字节可以存储 8 bit,示例结构,bit1 定义为 bit(8) 正好占用 1 字节,bit2...存储引擎返回 bit 类型字段给 server 层时,就是以 C/C++ 的 char * 指针返回的。...2.8 decimal 类型 decimal 类型存储引擎是以二进制存储的,发送数据之前,会先把二进制转换为浮点数,然后再把浮点数转换为字符串,把字符串内容长度和字符串内容发送给客户端。

1.5K10
您找到你想要的搜索结果了吗?
是的
没有找到

面银行软开,我最自信了!!

我们常说的索引数据结构,就是由存储引擎层实现的,不同的存储引擎支持的索引类型也不相同,比如 InnoDB 支持索引类型是 B+树 ,且是默认使用,也就是说在数据创建的主键索引和二级索引默认使用的是...每一种存储引擎支持的索引类型不一定相同,我总结了 MySQL 常见的存储引擎 InnoDB、MyISAM 和 Memory 分别支持的索引类型。...InnoDB 是 MySQL 5.5 之后成为默认的 MySQL 存储引擎,B+Tree 索引类型也是 MySQL 存储引擎采用最多的索引类型。...代码题 用两个栈实现队列 十进制转二进制 交通银行 说一下主键和索引 主键是用于唯一标识数据库每一行数据的字段字段组合。它具有以下特点: 主键必须是唯一的,每一行数据都必须具有唯一的主键值。...索引可以建立一个或多个列上,这些列可以是的任意字段。索引的创建过程会对指定的列进行排序和存储,以便快速定位和访问数据。

19010

从V8引擎来看JS这个假数组

那么数组的连续内存说的是,通过在内存划出一串连续且长度固定的空间,用来于存放一组有限且数据类型相同的数据结构。C/C++、Java等编译型语言中数组的实现都是这个。...快数组 先看快数组,快数组是一种线性存储,其长度是可变的,可以动态调整存储空间。其内部有扩容和收缩机制,来看一下V8扩容的实现。源码(C++): ....慢数组数组底层实现使用的是 HashTable 哈希,相比于快数组,他不用开辟大块的连续空间,从而节省内存,但无疑执行效率是比快数组要低的(时间换空间)。...当然有,那就是ES6ArrayBuffer。ArrayBuffer 对象用来表示通用的、固定长度的原始二进制数据缓冲区,它是一个字节数组。...使用ArrayBuffer能在操作系统内存得到一块连续的二进制区域。然后这块区域供JS去使用

1.4K20

MySQL 大对象(BLOB)和字符串的分身术

MySQL 有一些字段类型是用同一个 C++ 类或通过继承同一个 C++ 类的方式实现的。...定长字符串 定长字符串的实现类为 Field_string,有 2 种字段类型: CHAR,存储文本内容,字段长度固定,创建时指定的长度不是字节数,而是字符数,实际占用字节数取决于该字段的字符集。...BINARY,存储二进制内容,字段长度固定,创建时指定的长度为字节数。例如,字段 bin1 BINARY(10) 需要占用 10 字节。...变长字符串 变长字符串的实现类为 Field_varstring,有 2 种字段类型: VARCHAR,存储文本内容,字段长度不固定,创建时指定的长度不是字节数,而是字符数,最大占用字节数取决于该字段的字符集...VARBINARY,存储二进制内容,字段长度不固定,创建时指定的长度为字节数。例如:字段 varbin1 VARBINARY(32) 最大占用 32 字节

1.2K40

Protocol Buffer 序列化原理大揭秘 - 为什么Protocol Buffer性能这么好?

二进制串 对于C++,因为具有内存操作符,所以 二进制串 容易理解:C++的字符串可以直接被传输层使用,因为其本质上就是以 '\0' 结尾的存储在内存二进制串 对于 Java,二进制串 = 字节数组...优点 从上图可知,T - L - V 存储方式的优点是 不需要分隔符 就能 分隔开字段,减少了 分隔符 的使用字段 存储得非常紧凑,存储空间利用率非常高 若 字段没有被设置字段值,那么该字段序列化时的数据是完全不存在的...{ required int32 id1 = 1; required int32 id2 = 2; } // 代码给id1 附上1个字段值:296 // 代码给id2 附上1个字段值:296...str设置为:testing // 将Test2字段id1设置为:296 // 编码后的字节为:10 ,12 ,18,7,116, 101, 115, 116, 105, 110, 103,16,-...如果Field_Number>16时,Field_Number的编码就会占用2个字节,那么Tag在编码时也就会占用更多的字节;如果将字段标识号定义为连续递增的数值,将获得更好的编码和解码性能 建议3:若需要使用字段值出现负数

6.8K61

内存编织技术,JVM对内存的又一次压榨

如果你想知道怎么访问对象实例属性的底层原理,就得知道是如何存储的。存储搞明白了,访问就是一句话的事。而想搞明白存储,恰恰不是一件简单的事情。JVM对象实例属性的存储甚至比原生的C++对象还要复杂。...C++的实例属性存储 对比学习效果更佳!...先来看看C++的实例属性是如何存储的,上代码 图片 这段代码生成的对象在内存中长这个样子,占用16B,浪费了2B 如果我把代码改一下,int移到long的下方,又完全不一样了。...JVM的实例属性存储 说完了C++的对象内存模型,再来说说JVM的对象内存模型,两句话: 1、创建对象进行属性编织时,按照8字节、4字节、2字节、1字节、指针的顺序进行编织。...这时候就要找到对象的类信息,找到类信息存储的属性,然后才能完成取值。上伪代码 图片 思考题 数组对象的大小,其实在编译时是可以确定下来的,为什么要等到运行时动态计算出来?

34720

MySQL的varchar水真的太深了——InnoDB记录存储结构

InnoDB是一个将的数据存储到磁盘上的存储引擎。 ◆ 2. InnoDB是如何读写数据的?   ...注意:innodb_page_size变量服务器运行过程不可以更改,只能在第一次初始化MySQL数据目录时指定。所以页在运行时的大小不可更改。...——变长字段长度列表   一些变长的数据类型,比如VARCHAR(M)、各种TEXT类型,各种BLOB类型,变长数据类型的字段存储多少字节的数据是不固定的,存储真实数据的时候需要把这些数据占用的字节数也存起来...实际业务开发,几乎没有不使用varchar的,所以实际开发的记录都会有变长字段长度列表部分 3.4 记录为NULL,innodb如何处理?——NULL值列表   能仔细看到这里,你肯定是个高手了。...如果没有允许存储 NULL 的列,则 NULL值列表也不存在了,否则将每个允许存储NULL的列对应一个二进制位,二进制位按照列的顺序逆序排列。

2.1K30

深入理解CC++的指针

不考虑cpu缓存的情况下,计算机运行程序本质上就是对内存的数据的操作,通俗地来说,就是将内存条某些部分的数据搬进搬出或者搬来搬去,其中“搬进搬出”是指将内存二进制数据搬入cpu寄存器及运算器中进行相应的加减运算或者将寄存器的数据搬回内存单元...pb存储的都是地址,而且都是32位的二进制地址;再者,因为存储这样的地址需要4个字节,所以无论是int型指针变量pa或者是double 型指针变量pb,它们所占的内存大小都是四个字节,从这点来说...上面介绍的是指针变量的一个方面,指针变量还有另外一层含义:C/C++星号(*)被定义成取内容符号,虽然所有指针变量占的内存大小和存储的内存地址大小都是一样的,但是由于存储的只是数据的内存首地址,所以指针变量存储的内存地址所指向的数据类型决定着如何解析这个首地址...由于结构体s1存在字节对齐现象(以sizeof(double) = 8个字节对齐),所以s1占据24字节内存,而s2只占16字节。...知道这点,我们平常在设计结构体字段的时候,就可以合理安排字段顺序来使用更少的内存空间了。 函数指针   函数指针是指向函数的指针变量。 因而“函数指针”本身首先应是指针变量,只不过该指针变量指向函数。

99110

MySQL 简单查询语句执行过程分析(四)WHERE 条件

二)查询准备阶段 MySQL 简单查询语句执行过程分析(三)从 InnoDB 读数据 今天我们分为 3 个部分来介绍,首先会看一下 where 条件源码的结构是什么样的,对 where 条件结构有了初步了解之后...三种特殊类型字段怎么比较? 3.1 set 字段 set 类型的字段 InnoDB 以整数存储字段返回给 server 层时也是整数,定义结构时指定的每一个选项占用 1 bit。...语法分析阶段,find_in_set('金星', s1) 的金星就被解析成选项对应的整数值 1 << 16 = 65536,然后和存储引擎返回的整数值进行按位与(2163720 & 65536 =...3.3 bit 字段 bit 类型的字段存储引擎以 C/C++ 的 char 指针指向一块内存区域的形式,把字段内容返回给 server 层,server 层会把 char 指针指向的内存区域的内容转换为...字段的内容进行类型转换,而是直接和二进制 b'11011100' 进行相等比较,但实际上,server 层会把存储引擎返回的 bit1 字段的内容转换为浮点数,并且也会把 where 条件二进制

2.4K30

linux 编译汇编,linux下的汇编教程

linux下的汇编教程 第一部分 Linux下ARM汇编语法尽管Linux下使用C或C++编写程序很方便,但汇编源程序用于系统最基本的初始化,如初始化堆栈指针、设置页、操作 ARM的协处理器等。...(11).hword {,} … 插入一个16-bit的数据队列。(与armasm的DCW相同) 八....编译工具 1.编辑工具介绍 GNU提供的编译工具包括汇编器as、C编译器gcc、C++编译器g++、连接器ld和二进制转换工具objcopy。...GNU工具的开发流程如下:编写C、C++语言或汇编源程序,用gcc或g++生成目标文件,编写连接脚本文件,用连接器生成最终目标文件(elf格式),用二进制转换工具生成可下载的二进制代码。...(1)编写C、C++语言或汇编源程序 通常汇编源程序用于系统最基本的初始化,如初始化堆栈指针、设置页、操作ARM的协处理器等。初始化完成后就可以跳转到C代码执行。

3.4K31

# MySQL server 层和存储引擎层是怎么交互数据的?

原理说明 源码里,数据库的每个都会对应 TABLE 类的一个实例,实例中有个 record 属性,record 属性是一个有着 2 个元素的数组,server 层每次调用引擎层的方法读取数据时,都会用...当我们第一次查询某个的时候,MySQL 会从 frm 文件读取字段、索引等信息,以及刚刚提到的字段 Offset 、一条记录的最大长度。...这里的 char 是指的 C/C++ 里的 char,不是指的 MySQL 的 char 类型。...blob 类型的字段,最多可以存储 2 ^ 16 = 65536 字节 = 64K。...decimal 类型的字段存储引擎是用二进制存储的,创建的时候,就计算出来了需要用几字节存储存储引擎读取 d1 字段的内容之后,把内容写入 ptr 属性指向的内存空间。

1.3K30

MySQL全面的在线文档

MySQL企业版,线程池插件通过有效地管理大量客户端连接的语句执行线程来提高服务器性能。...安装 Using the MySQL Yum Repository Yum存储库安装手册。MySQL Yum存储库提供了用于Linux平台上安装MySQL服务器、客户端和其他组件的RPM包。...Using the MySQL SLES Repository 使用MySQL SLES存储SUSE Linux Enterprise Server (SLES)上安装和升级MySQL的用户指南。...涉及的应用程序接口包括低级c++语言的NDB AP、用于与NDB集群管理服务器通信和控制的C语言MGM API、以及用于Java的MySQL NDB集群连接器。...X DevAPI将文档存储集合,并有专门的CRUD操作集,使用现有的域对象或根据严格类型语言的结构定义生成代码通过CRUD操作使用文档。

2K40

protobuf 序列化和反序列化

使用二进制格式来编码数据,以提高传输效率和数据压缩比。 protobuf,我们可以使用.proto文件来定义消息类型,并使用编译器生成针对各种编程语言的序列化和反序列化代码。...编写应用程序:编写应用程序,创建消息对象并填充字段。 序列化数据:使用protobuf库,将消息对象序列化为字节数组。 传输数据:将字节数组发送给接收方。...反序列化数据:接收方使用protobuf库,将字节数组反序列化为消息对象,并访问其中的字段序列化过程,protobuf使用压缩技术来减小数据的大小,从而提高传输效率。...数组 json对象 注意事项: 一个文件只能存储一个大的数组或者对象, 但是可以嵌套使用 原素和原始之间使用逗号间隔(一个键值对视为一个元素) 最后一个元素后边没有逗号 { "lilii...这使得我们能够一个字段存储多个相关的数据,而无需定义多个独立的字段

39010

MySQL创建数据MySQL数据类型

数据需要以下信息: 名 表字段名 定义每个表字段 语法 以下为创建MySQL数据的SQL通用语法: CREATE TABLE table_name (column_name column_type...您可以使用多列来定义主键,列间以逗号分隔。 * ENGINE 设置存储引擎,CHARSET 设置编码。 通过命令提示符创建 通过 mysql> 命令窗口可以很简单的创建MySQL数据。...该节描述了这些类型如何工作以及如何在查询中使用这些类型。...0-255字节 短文本字符串 BLOB 0-65 535字节 二进制形式的长文本数据 TEXT 0-65 535字节 长文本数据 MEDIUMBLOB 0-16 777 215字节 二进制形式的中等长度文本数据...存储或检索过程不进行大小写转换。 BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。

5.8K71

MySQL的varchar水真的太深了——InnoDB记录存储结构

InnoDB是一个将的数据存储到磁盘上的存储引擎。 2. InnoDB是如何读写数据的?...实际业务开发,几乎没有不使用varchar的,所以实际开发的记录都会有变长字段长度列表部分 3.4 记录为NULL,innodb如何处理?...因为test的c1、c3、c4都是允许存储NULL值的允许为NULL的列,所以这3个列和二进制位的对应关系就是这样: NULL值列表必须用整数个字节的位表示,如果使用二进制位个数不是整数个字节,则在字节的高位补...MySQL,如果使用MEDIUMTEXT类型字段时,实际存储结构的设计确实允许存储的数据量超过单条记录通常的大小限制(例如,InnoDB的单行大小限制通常约为65535字节)。   ...这种方式允许MySQL存储大量的文本或二进制数据,远远超过单条记录的大小限制。   比如具体到MEDIUMTEXT,它可以存储最多16,777,215字节(约16MB)的数据。

1.6K40

MySQL 如何存储长度很长的数据字段

最近,在工作遇到了MySQL如何存储长度较长的字段类型问题,于是花了一周多的时间抽空学习了一下,并且记录下来。...我们可以看出,数据页存储了一部分数据,算下来一共是768字节,然后剩余部分存储在外部存储。那么数据页与外部存储页、外部存储页与外部存储页是如何连接在一起的呢? 我们观察这一行: ?...此种格式只用20字节指向外部存储空间。 将多个blob字段转为一个blob字段。多个字段可以用数组存储,然后json_encode打包进blob。 我们向插入一条有效记录: ?...外部存储页不共享,即使多余一个字节也是独享16KB的页面。 Dynamic行格式 接着我们首先看一下行格式为Dynamic是如何存储大数据的: ? 创建和compact格式一样的: ?...第4页是数据页,第5-9页是二进制页。我们直接看磁盘第4页的数据: ?

5.5K20

深入浅出 FlatBuffers 之 Encode

序列化数组 数组存储了连续的标量,并且还会存储一个 SizeUint32 代表数组的大小。数组不是内联存储它的父类,而是通过引用偏移 offset 的方式。...把数组的长度序列化到二进制数组的长度是 4 字节。...序列化 string 字符串可以看成字节数组,只不过字符串结尾处有一个空字符串标识符。字符串也不能内联存储它的父类,也是通过引用偏移 offset 的方式。...第三个是 N 个偏移量,其中 N 是编译构建此 buffer 的代码编译时(因此,的大小为 N + 2)时 schema 声明的字段数量(包括 deprecated 字段)。...Hp 字段有默认值,但是序列化的时候我们并没有用默认值,而是重新给他了一个新值,这个时候,二进制流中就会记录 Hp 的 offset,值也会存储二进制

7.1K74

MySQL的在线文档

MySQL企业版,线程池插件通过有效地管理大量客户端连接的语句执行线程来提高服务器性能。...安装 Using the MySQL Yum Repository Yum存储库安装手册。MySQL Yum存储库提供了用于Linux平台上安装MySQL服务器、客户端和其他组件的RPM包。...Using the MySQL SLES Repository 使用MySQL SLES存储SUSE Linux Enterprise Server (SLES)上安装和升级MySQL的用户指南。...涉及的应用程序接口包括低级c++语言的NDB AP、用于与NDB集群管理服务器通信和控制的C语言MGM API、以及用于Java的MySQL NDB集群连接器。...X DevAPI将文档存储集合,并有专门的CRUD操作集,使用现有的域对象或根据严格类型语言的结构定义生成代码通过CRUD操作使用文档。

2.4K20
领券