MySQL设计规范与原则

mysql数据库设计规范

1、数据库命名规范

采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线’_’组成;

命名简洁明确(长度不能超过30个字符);

例如:user, stat, log, 也可以wifi_user, wifi_stat, wifi_log给数据库加个前缀;

除非是备份数据库可以加0-9的自然数:user_db_20151210;

2、数据库表名命名规范

采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线’_’组成;

命名简洁明确,多个单词用下划线’_’分隔;

例如:user_login, user_profile, user_detail, user_role, user_role_relation,

user_role_right, user_role_right_relation

表前缀’user_’可以有效的把相同关系的表显示在一起;

3、数据库表字段名命名规范

采用26个英文字母(区分大小写)和0-9的自然数(经常不需要)加上下划线’_’组成;

命名简洁明确,多个单词用下划线’_’分隔;

例如:user_login表字段 user_id, user_name, pass_word, eamil, tickit, status, mobile, add_time;

每个表中必须有自增主键,add_time(默认系统时间)

表与表之间的相关联字段名称要求尽可能的相同;

4、数据库表字段类型规范

用尽量少的存储空间来存数一个字段的数据;

例如:能使用int就不要使用varchar、char,能用varchar(16)就不要使用varchar(256);

IP地址最好使用int类型;

固定长度的类型最好使用char,例如:邮编;

能使用tinyint就不要使用smallint,int;

最好给每个字段一个默认值,最好不能为null;

5、数据库表索引规范

命名简洁明确,例如:user_login表user_name字段的索引应为user_name_index唯一索引;

为每个表创建一个主键索引;

为每个表创建合理的索引;

建立复合索引请慎重;

6、简单熟悉数据库范式

第一范式(1NF):字段值具有原子性,不能再分(所有关系型数据库系统都满足第一范式);

例如:姓名字段,其中姓和名是一个整体,如果区分姓和名那么必须设立两个独立字段;

第二范式(2NF):一个表必须有主键,即每行数据都能被唯一的区分;

备注:必须先满足第一范式;

第三范式(3NF):一个表中不能包涵其他相关表中非关键字段的信息,即数据表不能有沉余字段;

备注:必须先满足第二范式;

数据库的三范式:

①字段不可分。

②有主键,非主键字段依赖主键。

③非主键字段不能互相依赖。

MYSQL数据库设计原则

1、核心原则

黑色全屏自适应的H5模板 黑色全屏自适应的H5模板

黑色全屏自适应的H5模板HTML5的设计目的是为了在移动设备上支持多媒体。新的语法特征被引进以支持这一点,如video、audio和canvas 标记。HTML5还引进了新的功能,可以真正改变用户与文档的交互方式,包括:新的解析规则增强了灵活性淘汰过时的或冗余的属性一个HTML5文档到另一个文档间的拖放功能多用途互联网邮件扩展(MIME)和协议处理程序注册在SQL数据库中存

黑色全屏自适应的H5模板 56 查看详情 黑色全屏自适应的H5模板

不在数据库做运算;

cpu计算务必移至业务层;

控制列数量(字段少而精,字段数建议在20以内);

平衡范式与冗余(效率优先;往往牺牲范式)

拒绝3B(拒绝大sql语句:big sql、拒绝大事物:big transaction、拒绝大批量:big batch);

2、字段类原则

用好数值类型(用合适的字段类型节约空间);

字符转化为数字(能转化的最好转化,同样节约空间、提高查询性能);

避免使用NULL字段(NULL字段很难查询优化、NULL字段的索引需要额外空间、NULL字段的复合索引无效);

少用text类型(尽量使用varchar代替text字段);

3、索引类原则

合理使用索引(改善查询,减慢更新,索引一定不是越多越好);

字符字段必须建前缀索引;

不在索引做列运算;

innodb主键推荐使用自增列(主键建立聚簇索引,主键不应该被修改,字符串不应该做主键)(理解Innodb的索引保存结构就知道了);

不用外键(由程序保证约束);

4、sql类原则

sql语句尽可能简单(一条sql只能在一个cpu运算,大语句拆小语句,减少锁时间,一条大sql可以堵死整个库);

简单的事务;

避免使用trig/func(触发器、函数不用客户端程序取而代之);

不用select *(消耗cpu,io,内存,带宽,这种程序不具有扩展性);

OR改写为IN(or的效率是n级别);

OR改写为UNION(mysql的索引合并很弱智);

select id from t where phone = ’159′ or name = ‘john’;

=>

select id from t where phone=’159′unionselect id from t where name=’jonh’

避免负向%;

慎用count(*);

limit高效分页(limit越大,效率越低);

使用union all替代union(union有去重开销);

少用连接join;

使用group by;

请使用同类型比较;

打散批量更新;

5、性能分析工具

show profile;

mysqlsla;

mysqldumpslow;

explain;

show slow log;

show processlist;

推荐教程:《MySQL教程》

以上就是MySQL设计规范与原则的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1035497.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 03:54:11
下一篇 2025年12月2日 03:54:32

相关推荐

  • 深入理解Web环境中PHP静态变量与数据持久化策略

    本文深入探讨了PHP在Web环境下静态变量的工作机制,指出其值不会跨HTTP请求持久化,因此不会对多用户平台造成数据混淆。文章强调了对于需要持久化存储的数据,应采用数据库或会话(Session)等外部存储方案,并简要对比了不同编程环境下的差异,提供了数据持久化的通用指导原则。 PHP Web环境下的…

    2025年12月10日
    000
  • 深入理解Web环境中静态变量的工作原理与数据持久化策略

    本文深入探讨了PHP等Web环境中静态变量的运作机制,解释了为何它们不适用于多用户平台的数据持久化。文章详细阐述了Web请求的无状态特性,并提供了数据库和会话数据作为实现数据持久化的核心策略,同时简要提及了Node.js等不同环境下的行为差异及其通用解决方案。 Web环境的无状态本质与静态变量 在理…

    2025年12月10日
    000
  • 精准定制:WooCommerce 购物车菜单在空状态下不显示数量的实现

    本教程旨在解决WordPress和WooCommerce网站中,购物车菜单在空状态下仍显示“0”的问题。通过修改functions.php文件中的代码,我们将学习如何条件性地渲染购物车商品数量,确保当购物车为空时,只显示购物车图标,从而优化用户界面体验。 引言:动态购物车图标的必要性 在现代电子商务…

    2025年12月10日
    000
  • 优化WooCommerce购物车图标:空购物车不显示数量

    本教程旨在解决WordPress + WooCommerce网站中购物车图标在空状态下仍显示“0”的问题。通过修改functions.php文件中的PHP代码,我们将实现当购物车为空时,仅显示购物车图标,而不显示数量圆圈及数字,从而提升用户界面简洁性和购物体验。 问题背景与目标 在wordpress…

    2025年12月10日
    000
  • Laravel Eloquent 模型更新方法详解:避免非静态调用错误

    本文旨在解决Laravel开发中常见的“非静态方法IlluminateDatabaseEloquentModel::update()不能被静态调用”错误。我们将详细讲解如何正确使用Eloquent的update方法进行批量数据更新和单条模型更新,包括带条件和不带条件的更新,以及利用fill()、sa…

    2025年12月10日
    000
  • PHP中从多维数组中查找指定键的最大值及其对应子数组

    针对PHP中处理包含多个子数组的多维数组场景,本文将详细介绍如何高效地查找并提取某个特定键(例如’bid’)具有最大值的子数组。通过结合使用array_column、max和array_keys函数,开发者可以精确地定位目标数据,从而简化复杂数据结构的筛选过程。 场景描述与示…

    2025年12月10日
    000
  • PHP 内存溢出错误:原因分析与解决方案

    PHP 内存溢出错误,即“Allowed memory size exhausted”,是 PHP 开发中经常遇到的问题。正如摘要所述,该错误表明脚本尝试分配的内存超过了 PHP 配置中允许的最大内存限制。 解决此问题通常有两种方法:一是增加 PHP 的内存限制,二是优化代码以减少内存占用。下面将详…

    2025年12月10日
    000
  • 从多维数组中高效提取指定键的最大值及其对应子数组的PHP方法

    本文详细介绍了如何在PHP中高效地从一个包含多个子数组的多维数组中,根据某个指定键(例如’bid’)的最大值,快速定位并提取出对应的子数组。通过利用PHP内置函数array_column、max和array_keys,可以简洁而有效地实现这一常见的数据处理需求,避免手动循环,…

    2025年12月10日
    000
  • PHP内存溢出错误:原因、排查与解决方案

    第一段引用上面的摘要: 本文旨在帮助开发者理解和解决PHP中常见的“Allowed memory size exhausted”错误。我们将深入探讨该错误产生的原因,包括脚本内存占用过高和内存限制设置不足,并提供实用的排查和优化方法,以及如何调整PHP内存限制,确保应用程序稳定运行。 错误原因分析 …

    2025年12月10日
    000
  • 使用 jQuery AJAX 指定重定向 URL 的方法

    本文介绍了在使用 jQuery AJAX 提交表单后,如何根据服务器返回的 JSON 数据中的特定 redirect 字段进行页面重定向。重点在于服务器端如何组织 JSON 响应,以及客户端如何解析该响应并执行重定向。同时,强调了这种方法只会重定向到最后一个满足条件的 URL,适用于只需要最新重定向…

    2025年12月10日
    000
  • AJAX 表单提交后基于服务器响应的动态重定向实现指南

    本教程详细阐述了如何通过 jQuery AJAX 提交表单后,根据服务器端处理结果实现动态页面重定向。核心在于服务器端根据业务逻辑在 JSON 响应中包含一个重定向 URL,客户端 JavaScript 接收到该响应后解析并执行跳转,确保用户体验的连贯性与业务流程的准确性。 概述 在现代 web 应…

    2025年12月10日
    000
  • 使用 jQuery AJAX 实现指定 URL 的重定向

    本文旨在介绍如何在使用 jQuery AJAX 提交表单后,根据服务器返回的 JSON 数据中的 redirect 字段,实现页面重定向。核心思路是在服务器端根据特定条件设置唯一的重定向 URL,并通过 AJAX 将其返回给客户端,客户端 JavaScript 代码则根据该 URL 进行重定向。 前…

    2025年12月10日
    000
  • 使用 jQuery AJAX 实现特定条件下的页面重定向

    本文介绍了如何使用 jQuery AJAX 根据服务器返回的 JSON 数据中的特定条件,实现灵活的页面重定向。通过在服务器端构建条件判断,并返回包含重定向 URL 的 JSON 数据,前端 AJAX 可以根据这些条件动态地更新 window.location.href,从而实现页面跳转。文章提供详…

    2025年12月10日
    000
  • PHP内存耗尽错误:深入理解与解决策略

    PHP脚本在执行过程中遇到“Allowed memory size exhausted”错误时,即使尝试分配的内存看似很小,也意味着脚本已达到其被允许使用的总内存上限。本文将详细解析此错误背后的机制,并提供两种核心解决方案:优化脚本以减少内存消耗,以及在必要时合理调整PHP的内存限制,旨在帮助开发者…

    2025年12月10日
    000
  • 高效处理数据库队列:实现条件式连续行处理策略

    本教程旨在解决数据库中按序处理数据时,如何实现条件式跳过并立即处理下一行的需求。通过引入 while 循环结构,结合条件判断和重试机制,确保脚本能够持续检查并处理满足特定标准的数据库记录,直至找到符合条件的行或达到预设的重试上限,从而避免不必要的等待,提高处理效率。 场景概述与问题背景 在许多自动化…

    2025年12月10日
    000
  • WooCommerce 产品配送预估:基于自定义分类和库存状态的动态显示教程

    本教程旨在指导您如何在 WooCommerce 单品页动态显示预计配送时间。通过集成自定义产品分类(如“立即有货”)和库存状态,我们将详细讲解如何编写代码,确保仅对符合特定条件的产品显示配送通知,并根据下单时间智能调整预计送达日期,从而显著提升用户体验和信息透明度。 引言:动态配送预估的重要性 在电…

    2025年12月10日
    000
  • PHP脚本优化:实现数据库记录的条件式顺序处理与即时跳过

    本文详细介绍了如何优化PHP脚本,以高效处理数据库中的队列数据。通过引入循环结构和条件判断,脚本能够即时跳过不符合特定条件的数据库记录,并立即处理下一条,从而避免了等待固定间隔时间(如20分钟)的低效模式,确保数据处理的连续性和及时性,同时提供了防止无限循环的健壮性机制。 优化数据库队列处理的挑战 …

    2025年12月10日
    000
  • WooCommerce教程:根据产品分类显示预计交货时间,并处理库存状态

    本文旨在帮助WooCommerce开发者根据产品所属的特定分类(taxonomy)来显示预计交货时间,并提供代码示例,同时涵盖了如何根据当前时间动态调整交货日期、自定义显示信息以及在产品缺货时隐藏交货提示的方法。通过学习本文,你将能够灵活地控制WooCommerce产品页面的交货信息展示,提升用户体…

    2025年12月10日
    000
  • WooCommerce产品页面:基于自定义分类和库存状态显示动态预计送达日期

    本教程详细指导如何在WooCommerce产品页面上,根据自定义分类(如“现货”)和库存状态动态显示预计送达日期。内容涵盖获取产品分类信息、判断库存状态、计算基于下单截止时间的送达日期范围,并生成自定义的提示信息,以提升用户体验。 引言 在电子商务中,清晰明确的送达时间预估对于提升用户信任和转化率至…

    2025年12月10日
    000
  • 在 WooCommerce 特定分类的产品中显示预计交货时间

    “本文档旨在指导开发者如何在 WooCommerce 商店中,针对特定分类(taxonomy)下的产品,显示预计交货时间。我们将修改现有的代码,使其仅在指定分类的产品页面上显示交货信息,并根据订单时间动态调整交货日期,同时处理缺货情况,提供更精确的预计交货时间提示。” 针对特定分类显示预计交货时间 …

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信