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

MySQL 8.0 数据字典

MySQL 8.0 对数据字典进行了重构,用户、数据字典MySQL 其它系统的元数据都统一保存到 mysql 库的数据字典中了。...数据字典本身也大变样了: 数据字典不再位于 InnoDB 系统空间,而是迁移到 mysql 库中,mysql 库位于 mysql 空间,磁盘文件为 mysql.ibd。...,如果想了解每个存放了什么内容,可以参照官方文档:https://dev.mysql.com/doc/refman/8.0/en/system-schema.html 默认情况下,我们是看不到数据字典的...除了数据字典,m_registry 中还包含了 mysql 库中的其它 MySQL 系统。...打开数据字典 数据字典保存着 MySQL 运行过程中需要的一系列关键数据,使用频次很高,MySQL 启动过程中就会把数据字典的元数据都加载到内存中,这就是打开的过程。

1.6K10

MySQL8.0​ 字典增强的意义

MySQL中数据字典是数据库重要的组成部分之一,INFORMATION_SCHEMA首次引入于MySQL 5.0,作为一种从正在运行的MySQL服务器检索元数据的标准兼容方式。...用于存储数据元数据、统计信息、以及有关MySQL server的访问信息(例如:数据库名或名,字段的数据类型和访问权限等)。 8.0之前: ?...1、元数据存在中 2、全部迁到mysql库下,改为innodb引擎,且被隐藏 3、information_schema下只能通过view查看 4、NULL的全部为view 5、存储在单独的空间...它也确实会尝试使用MySQL server层的缓存(系统变量table_definition_cache ),但是在大型实例中,很少有一个足够大的缓存来容纳所有的。...8.0 问世之后,又提供了一种选择,由于字典采用innodb引擎,而且字典可以使用索引。

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

业务中的字典MySQL实现方案

为什么需要字典? 某些变量在多个地方使用,而且一般固定,但随系统升级和后期变化,可能需要改变,如果这些变量写死在代码里面将会变得难以维护,所以要将其从代码中抽离。...设计字典 通常分成两张来实现,一个是字典类型,一个是字典 字典类型: SYS_DICT_TYPE 字段名 类型 作用 备注 code varchar 编码 主键 name varchar 类型 展示用...字典 : SYS_DICT ?...使用值 fixed int 是否是固定的 default 0不固定,固定的话用1 以上是字典的关键列和结构设计,根据不同系统不同业务自定其他列。...FAQ 字典类型应该不可编辑,因为字典类型通常会和具体代码实现紧密耦合,如果非要进行编辑话需要考虑到对代码的影响以及如何保证修改之后系统正常工作 字典分可编辑与不可编辑,所以在提供字典管理的时候需要注意

3.6K10

数据字典生成工具之旅(8):SQL查询的约束默认值等信息

date_type VARCHAR(50),--数据类型-- width INT,--数据宽度-- pk bit,--是否主键-- defaultvalue VARCHAR(100),--默认值...bit --是否主动增长-- ) AS /************************************************************** *函数功能:查询数据库中用户和视图的数据字典...VARCHAR(50),--数据类型-- width INT,--数据宽度-- pk bit,--是否主键-- defaultvalue VARCHAR(100),--默认值--...回到顶部 本章总结     通过几个系统视图的介绍和实际例子结合,完成了的详细信息的取数,数据字典生成工具和代码生成工具里面都有用到相关内容。...回到顶部 工具源代码下载       目前总共有经过了七个版本的升级,现在提供最新版本的下载地址 数据字典生成工具V2.0安装程序 最新安装程序 数据字典生成工具源代码 最新源代码 http://code.taobao.org

1K70

Oracle常用数据字典

Oracle常用数据字典      查看当前用户的缺省空间   SQL>select username,default_tablespace from user_users;   查看当前用户的角色...  SQL>select * from user_role_privs;   查看当前用户的系统权限和级权限   SQL>select * from user_sys_privs;   SQL...>select * from user_tab_privs;   查看用户下所有的   SQL>select * from user_tables;      查看用户下所有的的列属性      ...default_tablespace from user_users;   查看当前用户的角色   SQL>select * from user_role_privs;   查看当前用户的系统权限和级权限...  查看用户下所有的   SQL>select * from user_tables;   查看名称包含log字符的   SQL>select object_name,object_id from

66860

数据字典设计「建议收藏」

为什么字典?...所以通常把字典放在数据库,这样后期的维护变更就比较简单,也可以在不用修改代码的情况下修改配置。还有,对于某些固定的数据字典(例如,星期,月份等)不允许修改。...具体设计 通常分成两张来实现,一个是字典类型,一个是字典: 注意 字典类型应该是不可编辑的,因为字典类型通常会和具体代码实现紧密耦合,如果非要进行编辑的话需要考虑到对代码的影响以及如何保证修改之后系统正常工作...字典分可编辑与不可编辑,所以在提供字典管理的时候需要注意fixed字段,针对固定的字典不提供编辑功能 字典与系统参数不要混为一谈,字典通常用于一类的数据,一组具有相同含义的数值(例如,供客户端下拉选择的枚举...优化 数据字典数据应该存放在 redis 中,减少与数据库的交互次数,提高响应速度 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/127126.html原文链接:https

1.2K40

mysql分区_MySQL分区分

mysql中有一种机制是锁定和行锁定,是为了保证数据的完整性。锁定表示你们都不能对这张进行操作,必须等我对表操作完才行。...2、MySQL是将一个大按照一定的规则分解成多张具有独立存储空间的实体表,每个都对应三个文件,MYD数据文件,.MYI索引文件,.frm结构文件。...Mysql分为垂直切分和水平切分,具体区别如下: 垂直切分是指数据表列的拆分,把一张列比较多的拆分为多张 通常我们按以下原则进行垂直拆分: 把不常用的字段单独放在一张; 把text,blob(...例: 1)创建一个完整 mysql> create database test1; mysql> use test1; mysql> create table member -> ( -> id bigint...#创建两个分结构必须和上面完整的结构一致 mysql> create table tb_member1 like member; mysql> create table tb_member2 like

9.8K20

mysql默认的隔离级别

默认是可重复读” 面试官:“为什么mysql选可重复读作为默认的隔离级别?” (你面露苦色,不知如何回答!) 面试官:"你们项目中选了哪个隔离级别?为什么?" 你:“当然是默认的可重复读,至于原因。。...Mysql默认的事务隔离级别是可重复读(Repeatable Read),那互联网项目中Mysql也是用默认隔离级别,不做修改么?...正文 我们先来思考一个问题,在Oracle,SqlServer中都是选择读已提交(Read Commited)作为默认的隔离级别,为什么Mysql不选择读已提交(Read Commited)作为默认隔离级别...奈何这个格式在mysql5.1版本开始才引入。因此由于历史原因,mysql默认的隔离级别设为可重复读(Repeatable Read),保证主从复制不出问题!...缘由二:在RR隔离级别下,条件列未命中索引会锁

2.9K20

MySQL默认

本文标识 : MQ0020 本文编辑 : 长安月下赏美人儿 编程工具 : MySQL、DBeaver 阅读时长 : 6分钟 前言 关于之前的文章分享,大致同小伙伴儿们共同学习了一些基础的 MySQL...默认值问题的由来 在一个风和日丽的早晨,小编欢快的进行习题练习,插入了一个数据库,然后报错了,#1364 习惯性去网上查原因,于是发现了这个被忽略已久的问题,默认值。..." MySQL 严格模式需要注意的小问题 不支持对 not null 字段插入 null 值 不支持对自增长字段插 '' 值 不支持 text 字段有默认值 1、not null 字段插入 null...3、text 字段默认值测试 例,创建数据,设置 text 为默认值 default='' 在非严格模式下执行 CREATE TABLE test33 ( id INT(11) NOT NULL AUTO_INCREMENT...如何设置默认值 数据中单个字段 ALTER TABLE 数据名 MODIFY name VARCHAR (255) DEFAULT NULL; 同一个数据中多个字段 #用逗号(,)隔开即可 ALTER

4.1K10

数据库设计-简化字典

对于那些涉及到业务的或许不太好入手,但项目中经常出现的各种字典就很好入手了。项目越大那么字典就少不了,字典就是常见的类型、状态、单位之类特定的一些值。...有些人每一个业务或模块都设计一个字典用来标识类型或状态等等,这样的数量就不少了。其实我们可以将一些字典合并起来,用两个就能实现多个的功能。下面我以三个状态来演示。   ...也是不行的,如果需要对每个业务模块的字典进行维护,那第二张岂不是有两个业务模块与之对应,那样就显得有点不伦不类了。   接下来的这种方法合并的方法就显得更加的灵活转变了。...我们可以把每个业务模块假设成一个大类,而业务模块用到的字典数据就假设成小类。按这个思路就能把多个字典完成合并了。   ...,在去Status中添加与它对应的字典数据就行了。

2.3K30

java mysql 分区_mysql分区

对用户来说,分区是一个独立的逻辑,但是底层由多个物理子表组成。实现分区的代码实际上是对一组底层的句柄对象的封装。 mysql在创建时使用PARTITION BY子句定义每个分区存放的数据。...分区本身也有一些限制,下面是其中比较重要的几点: 1.一个最多只能有1024个分区。 2.在mysql5.1中,分区表达式必须是整数,或者是返回整数的表达式。...在mysql5.5中,某些场景中可以直接使用列进行分区。 3.如果分区字段中有主键或者唯一索引的列,那么所有主键列和唯一索引列都必须包含进来。 4.分区中无法使用外键约束。...update操作 当更新一条记录时,分区层先打开并锁住所有的底层mysql先确定需要更新的记录在哪个分区,然后取出数据并更新,再判断更新后的数据在哪个分区,最后对底层进行写入操作,并对原数据所在的底层进行删除操作...虽然每个操作都有“先打开并锁住所有的底层”,但这并不是说分区在处理过程中是锁住全的。如果存储引擎能够自己实现行级锁,例如innoDb,则会在分区层释放对应锁。

7.8K10

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券