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

MySQL数据库:表结构优化

由于MySQL数据库是基于行存储的数据库,而数据库IO操作的时候是以 page 的方式,也就是说,如果我们每行记录所占用的空间量减小,就会使每个 page 中可存放的数据行数增大,那么每次 IO 可访问的行数也就增多了...4、ENUM & SET: 对于状态字段,可以尝试使用 ENUM 来存放,因为可以极大的降低存储空间,而且即使需要增加新的类型,只要增加于末尾,修改结构也不需要重建表数据。...的数据类型可以精确到字段,所以当我们需要大型数据库中存放多字节数据的时候,可以通过对不同表不同字段使用不同的数据类型来较大程度减小数据存储量,进而降低 IO 操作次数并提高缓存命中率。...二、表结构设计: 上面几点的优化都是为了减少每条记录的存储空间大小,让每个数据库中能够存储更多的记录条数,以达到减少 IO 操作次数,提高缓存命中率。...1、适当拆分: 我们可能希望将一个完整对象对应一张数据库表,这对于应用程序开发来说是很友好的,但有时可能会在性能上带来较大的问题。

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

    MySQL数据库DDL表结构操作

    前言本专栏内容将会详细讲解MySQL数据库技术。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。 非常适合零基础的小伙伴来学习。...什么是表表 : 数据在数据库中是以一个一个表格形式存在并且组织的。 有行, 有列。图片二. 表结构操作1....数据表的修改(ALTER)修改表语法如下:ALTER TABLE 表名 操作;2.1 向现有表中添加列在表结构已经确定后, 如果想要增加一列可以使用下面语句进行更改:#在课程表基础上添加gradeId...结语最后,我们对本文核心要点进行总结:本节中主要学习的是DDL中的表结构的操作其中创建表语句, 删除表语句比较重要。...修改表结构语句一般使用较少,因为表结构设计创建后一般很少变动, 如果变动那么项目代码也会随之变动, 这样成本太高。

    3.7K10

    MySQL数据库(九):修改表结构

    前言: 1.修改表结构的时候受表中已存储数据的限制 2.查看表结构 desc 表名; 1.修改表结构 格式: alter  table  表名  修改动作; 2.修改动作 <add,modify...格式: alter  table  源表名  rename  [to] 新表名; 例子: 将t20表明修改为newt20 alter table  t20 rename newt20; 3.复制表...*注:源表表结构中key列的值不会被复制给新表 格式: create table 新表名  SQL查询; 例子: 复制newt20表的所有字段到t200表 create table t200 select...* from newt20; 值复制newt20表中的name,loves字段到t201表 create table t201 select name,loves from newt20; 4.只复制源表的表结构...格式: create table 新表名  select * from  源表名 where  条件; 例子: create table  t206 select * from t202 where

    7K50

    MySQL数据库学习·数据表重命名,复制,删除

    一.数据表重命名 RENAME TABLE asus To tb_asus; 总结语法: RENAME TABLE 数据表名 1 To 数据表名 2 --多个表之间以逗号“,” 二.数据表复制 CREATE...TABLE tb_user LIKE tb_asus; --将复制该表的列名,数据类型空指定和索引都将被复制,但表的内容不会被复制。...CREATE TABLE tb_user AS SELECT*FROM tb_asus; --将复制该表的列名,数据类型空指定和索引,以及表的内容都将被复制。...--若使用第二种方法复制,会发现信新复制出来的表并不包括原表中设置的主键,自动编号等,如果想要和原表完全一样,应使用下面语句。...CREATE TABLE tb_user SELECT * FROM tb_asus; 三.数据表删除 DROP TABLE [IF NOT EXISTS] 数据表名; --删除多个表用逗号隔开 Python

    4.5K41

    mongo复制数据库和表

    在同一个主机上从一个db的表复制到另一个db的表 db.collection_name.find().forEach(function(d){ db.getSiblingDB('new_database...')['collection_name'].insert(d);}) collection_name是数据库表名 new_database是目的数据库 克隆本地collection,mongodb没有提供命令进行本地复制...,但我们可以写一个循环插入的方法完成 例如:将source_collection中的数据复制一份到target_collection,代码如下: db.source_collection.find()....复制数据库 1.1 db.copyDatabase(fromdb,todb,fromhost,username,password,mechanism) 后面四个选项可选: * fromdbt...数据压缩:mongodb的存储结构采用了预分配的机制,长期不断的操作,会留下太多的的碎片,从而导致数据库系统越来越慢。

    6.2K20

    mysql复制系列6-复制信息相关的表

    复制状态信息查看可以通过一些语句如(show slave status)和相关的系统表来进行查看,它们之前有对应的关系 复制相关的表: 1.mysql.salve_master_info:包含从库与主库连接状态和当前的配置信息...,主库的ip、登录主库复制用户账号密码、io线程读取的主库二进制日志文件以及位置 (需要设置变量master-info-repository=TABLE) 2.mysql.slave_relay_log_info...(performance_schema库) 10.replication_group_member:记录组复制成员的网络和状态信息(performance_schema库) 复制信息查看show slave...status \G (我们经常使用的方式) mysql>show slave status\G; ***************************1.row*******************...baf0fafbff04:1-2879718702 --从库执行的事务的GTID SET Auto_Position:1 --是否启动自动定位 Replicate_Rewrite_DB: -- 主从数据库回放对应关系

    1.6K31

    mysql 数据库表结构设计与规范

    大家好,又见面了,我是你们的朋友全栈君 mysql 数据库表结构设计与规范 DDL(data difinition language)就是数据定义语言。...,而这个名字就是不存在的 mysql数据库使用的一些规范 通常来讲,各个互联网公司的数据库分为5个数据库环境: dev : 开发环境, 开发可读写,可修改表结构; 常用的163的数据库表; 开发人员可以修改表结构...,会先在这个环境上进行预执行, 这个环境也可供部署上线演练或压力测试使用 可以读写 real: 生产数据库从库(准实时同步),只读环境,不允许修改数据,不允许修改表结构; 供线上问题查找,数据查询等使用...充分利用前缀索引 尽量不使用存储过程、触发器、函数等,让数据库做最擅长的事 避免使用大表的JOIN,MySQL优化器对join优化策略过于简单 避免在数据库中进行数学运算和其他大量计算任务...(相比直接alter table改表) 修改的表需要有唯一键或主键 在同一端口上的并发修改不能太多 MySQL集群方案 基于主从复制; 基于中间件/proxy 基于NDB引擎

    2.4K40

    数据库MySQL-复制

    复制 复制的本质是可以帮助MySQL分担读负载, 并不能实现写负载. MySQL的高可用可以为高可用, 灾难恢复, 备份提供了很多的选择....MySQL的复制是基于主库上的binglog二进制日志来进行增量推送的, 所以在同一个时间内如果从主库写入数据, 然后快速的向从库读取数据是没有办法做到十分准时的 2....MySQL的复制解决了什么问题 实现了在不同服务器上的数据分布 利用二进制的日志增量进行 不需要太多的带宽 但是使用基于行的复制在进行大批量的更改时会对贷款带来一定的压力 实现数据读取的负载均衡 需要其他组件配合完成...MySQL日志 1.1 MySQL服务层日志 二进制日志 慢查日志 通用日志 1.2 MySQL存储引擎层日志 innodb 的事务提交日志和回滚日志 二进制日志 纪录了所有对MySQL数据库的修改事件...包括增删改查时间和对表结构的修改事件 备注:binlog日志只会记录事务成功提交的日志, 未成功的不会存储 二进制日志的格式 基于段的格式 binlog_format = STATEMENT 优点

    2.2K20

    数据库导出表结构语句_sqlserver导出表结构

    ,到时候只需要修改成你要导出表结构的数据库即可 table_schema ='test_database' -- AND -- test_table为表名,到时候换成你要导出的表的名称...-- 如果不写的话,默认会查询出所有表中的数据 table_name = 'test_table' 运行之后显示: 之后选中复制粘贴到文档中即可 这种方法的不足之处是 查询整个数据库所有的表的结构时...---- 第二种 :利用SQLyog的导出html功能 SQLyog的使用就不多说,直接去官网下载傻瓜式安装运行即可 运行之后连接数据库,右键选中需要导出表结构的数据库,选择最下面的Create Schema...或者oracle数据库表结构设计文档 链接:https://www.jianshu.com/p/884aff422649 项目下载运行之后: 如上填写完信息之后 测试连接成功之后 就可以 导出文档:...唯一的不足之处是不能选择导出某个或几个表的结构,只能选择某个数据库所有表 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

    5.9K10

    MySQL innodb表使用表空间ibd文件复制或迁移表

    MySQL InnoDB引擎的表通过拷贝物理文件来进行单表或指定表的复制,可以想到多种方式,今天测试其中2种: 将innodb引擎的表修改为Myisam引擎,然后拷贝物理文件 直接拷贝innodb的表空间文件...(前提是独立表空间(默认,通过show variables like 'innodb_file_per_table' 查看))进行复制 一、修改引擎 1.创建一张innodb引擎的表,并插入测试数据;...将物理文件拷贝至目标库 cd /data/mysql/mysql3307/data/ cd testdbllcd ../testdb2/pwdllcp .....4.修改权限 chown -R mysql:mysql . 5. 查看结果 ? 记录和源库一致。 6....所以建议先锁表或停止业务,待拷贝文件后再恢复写入等操作。 此方法在某些场景下将可能导致数据库重启,慎用!!!

    4.5K20
    领券