char 和 varchar 的区别,数据库索引B+树

char 和 varchar 的区别

char(n) :固定长度,效率高;缺点:占用空间;存储固定长度的,使用 char 非常合适。

varchar(n) :可变长度,存储的值是每个值占用的字节再加上一个用来记录其长度的字节的长度。

索引建立原则:在频繁使用的、需要排序的字段上建立索引。

InnoDB 存储引擎的默认索引为 B+ 树索引 ,B+ 树只有叶子节点才存储数据,其他都是索引, B+ 树元素自底向上插入。

B+树的特征:

1.有k个子树的中间节点包含有k个元素(B树中是k-1个元素),每个元素不保存数据,只用来索引,所有数据都保存在叶子节点。

2.所有的叶子结点中包含了全部元素的信息,及指向含这些元素记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。

3.所有的中间节点元素都同时存在于子节点,在子节点元素中是最大(或最小)元素。

B+树的优势:

1.单一节点存储更多的元素,使得查询的IO次数更少。

2.所有查询都要查找到叶子节点,查询性能稳定。

3.所有叶子节点形成有序链表,便于范围查询。

所有记录都在叶节点中,并且是顺序存放的,如果我们从最左边的叶节点开始顺序遍历,可以得到所有键值的顺序排序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/438306.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

日常收集C#接口知识(知识全面)

本文分为七章节给大家介绍c#接口知识,内容比较详细,特此分享脚本之家平台,供大家参考 第一节 接口慨述 接口(interface)用来定义一种程序的协定。实现接口的类或者结构要与接口的定义严格一致。有了这个协定&#xff…

mysql按照中文首字母拼音排序

order by convert(排序字段 using gbk)

C#基础操作符详解

本节内容: 1.操作符概览; 2.操作符的本质; 3.操作符与运算顺序 4.操作符详解。 1.操作符概览: 操作符(Operator)也译为”运算符” 操作符是用来操作数据的,被操作符操作的数据称为操作数&a…

查询sql语句是否使用索引

使用 Explain 命令来查看语句的执行计划 例:Explain select * from table 除过select,其他比如insert,update和delete均可以使用explain查看执行计划 概要描述: id:选择标识符 select_type:表示查询的类型。 table:输出结果集的…

C# 有什么惊艳到你的地方?

作者:皮皮关 链接:https://www.zhihu.com/question/335137780/answer/786853293 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 很多游戏开发者都是由于Unity而“被迫”使用C#的。但用过一段…

Redis使用场景

缓存:减轻查询压力,提升系统性能; 排行榜:利用 Redis 的 SortSet(有序集合)实现; 计数器/限速器:利用 Redis 中原子性的自增操作,我们可以统计类似用户点赞数、用户访问…

SqlServer学习之存储过程

前言:对于存储过程一直有一种抵触的心理,因为毕业至今所在的公司开发组都不是很规范,对于开发的一些注意事项并没有很多的规定,只是在知乎上查找相关知识的时候,看到很多人对于在程序里使用存储过程的不好之处都有很多…

Redis 支持的数据类型

string 字符串:一个key 对应一个 value。string 类型是二进制安全的, string 可以包含任何数据,比如图片或者序列化的对象,value 最多可以是 512MHash(哈希):hash 是一个键值对集合,…

中间件之RPC

一、RPC的定义 1、RPC(Romote Procedure Call):远程过程调用,允许一台计算机程序远程调用另外一台计算机的子程序,不用关心底层网络通信 2、应用:分布式网络通信 3、在Socket的基础上实现,比socket需要更多资源 4、…

Redis 持久化方式

Redis 提供了两种持久化方式:RDB (默认) 和 AOF。 RDB 内存快照,简而言之,就是在不同的时间点,将 redis 存储的数据生成快照并存储到磁盘等介质上 AOF 日志文件:AOF的全称叫append-only file&…

需求分析之UML用例图学习

用例图常用的三种关系浅析: (一)泛化(Inheritance) 通常理解的继承关系 (二)包含(include) 分解功能,一定包含的功能 (三)拓展(extend) 附加功能&#xff0c…

RSA公私钥加解密方式-工具类

直接上代码 ​ import java.io.ByteArrayOutputStream; import java.math.BigInteger; import java.security.*; import java.security.interfaces.RSAPrivateKey; import java.security.interfaces.RSAPublicKey; import java.security.spec.PKCS8EncodedKeySpec; import jav…

UML之用例图(use case)箭头方向

1、Association,无箭头,Actor连接UseCase即可; 2、DirectedAssocition,Actor连接UseCase,箭头由Actor指向UseCase(角色指向用例); 3、Generalization,继承,…

MD5加密方式-工具类

import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.security.MessageDigest;/*** Md5加密方法* * author */ public class Md5Utils {private static final Logger log LoggerFactory.getLogger(Md5Utils.class);private static byte[] md5(String s){Mes…

UML-记忆技巧

箭头方向 UML箭头方向:从子类指向父类,读作继承自定义子类时需要通过extend关键字指定父类子类一定时知道父类定义的,但父类并不知道子类的定义 只有知道对方信息时才能指向对方 image.png 实现-继承|虚线-实现 空心三角箭头&#xff1…

动态定时任务数据库获取方式

Spring 中,创建定时任务除了使用Scheduled 注解外,还可以使用 SchedulingConfigurer。 Schedule 注解有一个缺点,其定时的时间不能动态的改变,而基于 SchedulingConfigurer 接口的方式可以做到。SchedulingConfigurer 接口可以实…

国密算法SM2,SM3,SM4-java实现

SM2是国家密码管理局于2010年12月17日发布的椭圆曲线公钥密码算法,基于ECC。其签名速度与秘钥生成速度都快于RSA,非对称加密,该算法已公开 SM3是中华人民共和国政府采用的一种密码散列函数标准,由国家密码管理局于2010年12月17日…

数据库事务隔离级别-- 脏读、幻读、不可重复读(清晰解释)

一、数据库事务隔离级别 数据库事务的隔离级别有4个,由低到高依次为Read uncommitted 、Read committed 、Repeatable read 、Serializable ,这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。 √: 可能出现 : 不会出现 脏读不可重复读幻…

国密算法SM2-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> 工具类 import java.math.BigInteger;public class Util {/*** 整形转换成网络…

原子性和一致性的区别是什么?

注&#xff1a; 重度参考了&#xff1a;https://www.zhihu.com/question/30272728/answer/72476703&#xff08;讲的非常好&#xff0c;逻辑清晰&#xff09; 轻度参考了&#xff1a;https://www.cnblogs.com/fjdingsd/p/5273008.html&#xff08;概念也比较清晰&#xff0c;…