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

MySQL数据库结构设计

在编码过程中,如果MySQL数据结构设计不好的话,会大大影响开发人员编码效率。比如说MySQL数据库设计不规范,创建时间字段设计成cjsj,创建者字段设计成cjr或者cjz。...这样的数据库表可读性和表意性相当差。下面我们就来讲讲如何规范设计数据库结构数据库结构优化 数据库结构优化的目的有哪些? 减少数据冗余。 尽量避免数据维护中出现更新,插入,删除异常。...解决上述异常很简单,设计数据库表时遵循数据库三大范式即可。 数据库结构设计又分为逻辑设计和物理设计。 前面说的数据库三大范式可以说是逻辑设计。逻辑设计是根据数据实体之间的逻辑关系对表进行设计。...一个好的逻辑设计可以解决数据冗余和数据维护的异常,反之亦然。 物理设计则是根据所使用的数据库特点进行表结构设计。...维护优化是指根据实际情况对索引存储结构等进行优化。 一般数据库结构设计的步骤是: 1.需求分析:全面了解产品设计的存储需求。存取需求是指数据库要存储什么样的数据,这些数据具有什么特点。

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

mysql 数据库结构设计与规范

大家好,又见面了,我是你们的朋友全栈君 mysql 数据库结构设计与规范 DDL(data difinition language)就是数据定义语言。...,而这个名字就是不存在的 mysql数据库使用的一些规范 通常来讲,各个互联网公司的数据库分为5个数据库环境: dev : 开发环境, 开发可读写,可修改表结构; 常用的163的数据库表; 开发人员可以修改表结构...,会先在这个环境上进行预执行, 这个环境也可供部署上线演练或压力测试使用 可以读写 real: 生产数据库从库(准实时同步),只读环境,不允许修改数据,不允许修改表结构; 供线上问题查找,数据查询等使用...例如用户名w_wap, r_wap 能看出来,读写帐号是wap应用的 数据库开发规范 开发规范本身也包含几部分:基本命名和约束规范,字段设计规范,索引规范,使用规范等 规范存在意义 保证线上数据库schema...5.5.3以后支持) 存储引擎使用InnoDB 变长字符串尽量使用VARCHAR VARBINARY 不在数据库中存储图片、文件 设计表的时候需要添加注释 单表数据量控制在

2.3K40

MYSQL 数据库结构优化

数据库结构优化 优化数据大小 使表占用尽量少的磁盘空间。减少磁盘I/O次数及读取数据量是提升性能的基础原则。表越小,数据读写处理时则需要更少的内存,同时,小表的索引占用也相对小,索引处理也更加快速。...如果主要的负载在缓存命中率及磁盘读写速度,那么这种格式将能够提升数据库反应速度。如果是极端情况负载受限于CPU性能,那么使用这种格式则会降低数据库性能。...对于InnoDB 类型表,主键列博阿含在二级索引中,所以对于具有较多二级索引的数据库结构,较短的主键能够节省相当的存储空间。 不要创建不必要的索引。索引能够加快查询,但是会影响插入和更新操作。...设计表只存储最常用的少数列,使得读取数据时,一个数据块能够包含更多的数据行,从而减少磁盘I/O和内存使用。 如果使用随机生成的值作为InnoDB 表主键,最好前置一些自增的值,如当前的时间戳等。...同一个数据库中表过多的缺点 如果数据库中MyISAM 表过多,打开,关闭和创建表操作会变得很慢,当执行多表查询时,可能会发生表缓存溢出。

7.5K51

MySQL数据库设计

mysql:    dbs  数据库系统    bdms  数据库管理系统    bda   数据库管理员    db    数据库    dba通过dbms来操作db!...软件项目开发周期中数据库设计 01.需求分析阶段:分析客户的业务和数据处理需求 02.概要设计阶段:设计数据库的E-R模型图,确认需求信息的正确和完整 03.详细设计阶段:应用三大范式审核数据库结构 04...数据库的备份 cmd进入命令行 mysqldump -u用户名 -p 数据库名称 >指定的文件 数据库的恢复 前提是必须要有对应的数据库  mysql -u用户名 -p <指定的文件 1. mysql...为DOS命令 2.在执行该语句之前,必须在MySQL服务器中创建新数据库,如果不存在恢复数据库过程将会出错 关系型数据库和非关系型数据库  登录mysql   mysql  -h主机地址   -u用户名...第三范式:在满足第二范式基础上,保证表中除主键列外的其他列,都直接依赖于主键列,则符合第三范式 设计没有好坏,没有对错之分,所谓仁者见仁智者见智 1.MySQL的优势  1.运行速度快,  2.使用成本低

2.6K110

MySQL数据库设计

目录: 三大范式 ER图 PowerDesigner工具 数据库设计三大范式 范式是符合某种设计要求的总结,关系型数据库中有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴德斯科范式...第一范式 每个字段不可再分割,数据库表中每一列都是原子项的数据。 如:下面表就不符合第一范式 为什么? 因为address列不具有原子性,还可以分割。...班主任编号都直接依赖于学号,班主任姓名和班主任年龄没有直接依赖于学号,而它依赖的是班主任编号(非主键字段); 对上表进行修改,使其符合第二范式,如下面两个表: 1、学生表 2、班主任表 注意: 在实际开发过程中,所有表的设计都必须满足第一范式要求...因为性能的优先级要高于规范的优先级(当性能和规范冲突时以性能为主),特别是电商项目中,为了满足性能要求去违背设计规范。...角色表: 权限(菜单)表: 角色权限表: PowerDesigner 这是一个建立数据库模型,生成数据库的工具。

1.8K30

MySQL树形结构(多级菜单)的数据库设计和查询

说下我是怎么想起设计这个东西的,在一个惠风和畅,风和日丽的午后,我盯着眼前已完成的项目陷入沉思,良久,我将树形菜单的每一级菜单都设计成为了单独的表,正准备写接口将所有的菜单都返回的时候,带我的哥哥给我讲了一遍树形菜单的结构数据库如何设计...数据库设计 其实简单来讲就是为每个菜单栏在添加一个parent_id字段,记录着自己父菜单的ID,以下面的菜单为例,我给出了对应数据库简单的设计,想必你一看就明白了。...树形菜单的查询 数据库设计虽然已经完成了,但是我们如何实现查询呢?...前端需要的是我们返回的树状菜单结构,那么我们自然需要一个对象去封装一下,在这里运用一下面向对象的思想考虑一下这个返回的对象要怎么封装吧 继续浏览查找答案吧。

9.5K10

数据库设计概念结构设计_数据库设计典型实例

文章目录 数据库设计 概念设计结构 概念结构设计 ER模型的基本元素 实体/实体集 属性 区别实体和属性 联系 二元联系的关系 1:1 1:n m:n 一元联系 1:1 1:n m:n...三元联系 采用ER模型的概念设计 设计局部ER模型 例题 设计全局ER模型 全局ER模型的优化 数据库设计 数据库设计:构造最优的数据模型,建立数据库及其应用系统的过程 数据库设计的好坏非常重要...概念设计结构 概念设计的目标是产生反映用户需求的数据库概念结构,即概念模型 概念模型具有硬件独立、软件独立的特点 处于一个桥梁作用 概念设计的主要步骤 概念设计的方法 实体练习方法...(ER方法) 概念结构设计 ER模型的基本元素 实体/实体集 实体 实体是指数据对象,指应用中可以区别的客观存在的事物。...采用ER模型进行数据库的概念设计的步骤 首先设计局部ER模型 然后把各局部ER模型综合成一个全局ER模型 最后对全局ER模型进行优化,得到最终的ER模型,即概念模式 设计局部ER模型 要点是区分实体和属性

1.1K20

MySQL数据库:表结构优化

数据库操作中最为耗时的操作就是 IO 处理,大部分数据库操作 90% 以上的时间都花在了 IO 读写上面。所以减少 IO 次数可以在很大程度上提高数据库操作的性能。...由于MySQL数据库是基于行存储的数据库,而数据库IO操作的时候是以 page 的方式,也就是说,如果我们每行记录所占用的空间量减小,就会使每个 page 中可存放的数据行数增大,那么每次 IO 可访问的行数也就增多了...4、ENUM & SET: 对于状态字段,可以尝试使用 ENUM 来存放,因为可以极大的降低存储空间,而且即使需要增加新的类型,只要增加于末尾,修改结构也不需要重建表数据。...二、表结构设计: 上面几点的优化都是为了减少每条记录的存储空间大小,让每个数据库中能够存储更多的记录条数,以达到减少 IO 操作次数,提高缓存命中率。...下面这个优化建议可能很多开发人员都会觉得不太理解,因为这是典型的反范式设计,而且也和上面的几点优化建议的目标相违背。

7K10

MySQL系列 | MySQL数据库设计规范

规范背景与目的 MySQL数据库与 Oracle、 SQL Server 等数据库相比,有其内核上的优势与劣势。我们在使用MySQL数据库的时候需要遵循一定规范,扬长避短。...本规范旨在帮助或指导RD、QA、OP等技术人员做出适合线上业务的数据库设计。在数据库变更和处理流程、数据库设计、SQL编写等方面予以规范,从而为公司业务系统稳定、健康地运行提供保障。 2....设计规范 2.1 数据库设计 以下所有规范会按照【高危】、【强制】、【建议】三个级别进行标注,遵守优先级从高到低。 对于不满足【高危】和【强制】两个级别的设计,DBA会强制打回要求修改。...2.1.2 表结构 【强制】表和列的名称必须控制在32个字符以内,表名只能使用字母、数字和下划线,一律小写。...因为Innodb表支持事务、行锁、宕机恢复、MVCC等关系型数据库重要特性,为业界使用最多的MySQL存储引擎。而这是其他大多数存储引擎不具备的,因此首推InnoDB。

3.2K30

数据库结构设计

大家好,又见面了,我是你们的朋友全栈君 为什么要学习数据表结构设计 实际开发中,需要根据需求,将实际模型转换成物理表结构,这时需要考虑几个问题,表名称如何命名,表中需要哪些字段,各个字段的命名规范...---- 推荐使用的工具 PowerDesigner这个工具,可以做UUML图帮助分析数据关系,最重要的是可以把设计好的表结构转换成你使用的数据库的命令语句,方便在数据库中使用 工具网盘链接:链接...:https://pan.baidu.com/s/1gggehLx 密码:d302 ---- 常见几个字段的设计 以部门表为例,需要编号,部门名称,部门状态,父部门编号(外键) 表名称:DEPT_P...以防日后需要再使用到 部门名称:dept_name varchar(40) 部门名称有可能是英文中文,可以在询问客户的部门名称最大长度的基础乘以3-4倍,就是部门名称的长度 ---- 使用PD自动生成数据库命令语句

92610

MySQL性能管理及架构设计(二):数据库结构优化、高可用架构设计数据库索引优化

一、数据库结构优化(非常重要) 1.1 数据库结构优化目的 1....总结:要避免异常,需要对数据库结构进行范式化设计。 3. 节约数据存储空间。 4. 提高查询效率。...1.2 数据库结构设计步骤 需求分析:全面了解产品设计的存储需求、数据处理需求、数据安全性与完整性; 逻辑设计(重要):设计数据的逻辑存储结构。数据实体之间的逻辑关系,解决数据冗余和数据维护异常。...数据范式可以帮助我们设计; 物理设计:表结构设计,存储引擎与列的数据类型; 维护优化:****索引优化、存储结构优化。 1.3 数据库范式设计与反范式化 1.4 物理设计 ? ? ?...二、高可用架构设计 ? ? 2.1 读写分离 ? 三、数据库索引优化(非常重要) 3.1 两种主要数据结构:B-tree和Hash 3.1.1 B-tree结构 ? B-tree索引的限制: ?

79110

MySQL数据库DDL表结构操作

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

3.7K10
领券