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

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

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

10.7K10

【MySQL】数据库和表的操作

数据库和表的操作 一、数据库的操作 1....:use test1 然后我们为这个数据库创建一张表,并插入一些数据,创建表和插入的语法我们先不做介绍,后面再介绍;如下: 接下来我们对这个表的插入结果进行查看,注意,该表的校验方法是不进行区分大小写进行匹配的...执行删除之后的结果: 数据库内部看不到对应的数据库 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删 5. 备份和恢复 (1)备份数据库 在备份数据库之前我们先需要退出 mysql....users 表存储引擎是 MyISAM ,在数据库目录中有三个不同的文件,我们可以进入该目录查看:cd /var/lib/mysql/d1,分别是: 其中,它们分别表示: users.frm:表结构 users.MYD...:表数据 users.MYI:表索引 而 db.opt 则是该数据库对应的字符集和检验规则。

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

    MySQL数据库表设计规范

    一、数据库设计 1、一般都使用 INNODB 存储引擎,除非读写比率的建议下使用。...二、数据库对象设计规范 1、表 设计 a)在设计时尽量包含两个日期字段:crt_time(创建日期),upd_time(修改日期)且 非空, 对表的记录进行更新的时候,必须包含对 upd_time字段的更新...c)需要多表join的字段,数据类型保持绝对一致。 d)Mysql 的表尽量设置成 KV(Key-Value)结构,这样便于扩展和维护。...h)由于MYSQL表DDL维护成本很高,所以在适当的时候,可以有一定的字段容余。 比如:Value1,Value2,Value3 这样的字段。...c) 当删除约束的时候,为了确保不影响到 index,最好加上 keep index 参数。 d) 主键的内容不能被修改。 e) 外键约束一般不在数据库上创建,只表达一个逻辑的概念,由程序控制。

    2.8K30

    MySQL:表的设计原则和聚合函数

    所属专栏:MySQL学习 1. 表的设计原则 1. 从需求中找到类,类对应到数据库中的实体,实体在数据库中表现为一张一张的表,类中的属性对应着表中的字段 2. 确定类与类的对应关系 3....: 学号 姓名 年龄 课程名称 学分 成绩 202201 张三 19 MySQL 3 100 其中,年龄和姓名依赖学号(对应唯一学号),学分依赖课程名称,成绩通过学生和课程共同区分,也就是这个表中可以用学生和课程作为复合主键来确定学生当前的课程成绩...更新异常 如果需要修改MySQL的学分,那么就需要修改表中所有关于MySQL的记录,如果说只有部分数据修改成功,剩余的还是原来的数据,就会出现数据不一致,造成数据混乱 3....三种关系 3.1 一对一关系 例如设计一个登录界面,输入用户名和密码登录成功之后,显示欢迎用户,这样的场景一般对应两个实体,用户和账号,并且一个用户只对应一个账号,就是一对一的关系 针对一对一关系设计表时有两种方式...第一种就是把两个实体所有的信息放在一张表中 use_id name phone_number username password 第二种就是设计两张表,分别记录用户信息和账号信息,再把两张表关联起来

    9910

    MySQL 数据库和表操作

    MySQL服务器中的 【数据库】 以文件夹的形式存放在data目录下,本章讲解如何优雅地使用SQL命令操作数据库和数据表。...2.创建数据库 CREATE DATABASE 库名; #查看数据库 show databases; 3.指定数据库 若要操作数据库中的表或数据则需要先指定使用哪个库; #指定使用mysql库 USE...mysql; 如果想连接上数据库就可以使用某个库,可以在登录的时候指定库 #例如登录MySQL服务器 指定使用mysql库 mysql -uroot -p mysql #查看当前使用的库 SELECT...思路2): 利用 mysqldump备份工具 备份某个数据库,再导入到新库中(细品~)。 mysqldump工具是MySQL官方的一种数据备份工具,安装完mysql服务器的同时也装上了此工具。...查看表 show tables; 5.删除数据表 #好了,玩乱了吧,该删除了... # (1) drop 永久删除表,删除表全部数据和表结构,立刻释放磁盘空间 drop table 表名; #

    6.1K30

    Mysql实例 数据库优化--数据库表设计

    SQL效率 其它 根据上述问题,将数据库的优化分为几个阶段进行调整,力求让数据库发挥好的性能和稳定运行。...二.数据库表设计 项目立项后,开发部门根据产品部门需求开发项目。开发工程师在开发项目初期会对表结构设计。对于数据库来说,表结构设计很重要,如果设计不当,会直接影响到用户访问网站速度,用户体验不好!...由于开发工程师重视点不同,初期不会考虑太多数据库设计是否合理,而是尽快完成功能实现和交付。等项目上线有一定访问量后,隐藏的问题就会暴露,这时再去修改就不是这么容易的事了!...15.避免发生隐式类型转换 类型转换主要是指在WHERE子句中出现字段的类型和传入的参数类型不一致的时候发生的类型转换;这是因为如果传入的数据类型和字段类型不一致,MySQL可能会对数据进行类型转换操作...17.建议开启查询缓存 大多数的MySQL服务器都开启了查询缓存,这是提高性能最有效的方法之一,因为查询缓存由MySQL数据库引擎自动处理,当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中

    2.4K10

    MySQL表的物理设计

    在设计好表结构之后, 就需要进行物理设计, 将实体及属性映射到具体表和列. 而合理选择存储引擎和列类型也是数据库设计十分重要的一个环节....物理设计包括, 命名规范, 存储引擎, 列字段选择, 主键设计以及主键生成算法. 一. 命名规范 首先在定义数据库,表,字段时一定要公司的命名规范; 二....中字符串类型主要有两种varchar 和 char, 如果是非常大的文本可以酌情选择text类型....主键选择 应选择尽可能小且顺序增长的数字类型, 并且表主键可以与业务主键不同....原因是表的主键上, 会自动建立主键索引(B+树), 如果是自增的数字类型, 只需要在索引尾部添加数据即可, 性能开销很小; 当主键采用字符串类型时, 占用的空间会远大于数字类型.

    1.3K10

    MySQL - 高效的设计MySQL库表

    范式与反范式 范式 范式是关系数据库理论的基础,也是我们在设计数据库结构过程中所要遵循的规则和指导方法。数据库的设计范式是数据库设计所需要满足的规范。...使用原则和设计规范 聊完范式,接下来我们看看 MySQL 使用中的一些使用原则和设计规范。...想要发挥 MySQL 的最佳性能,需要遵循 3 个基本使用原则 首先是需要让 MySQL 回归存储的基本职能:MySQL 数据库只用于数据的存储,不进行数据的复杂计算,不承载业务逻辑,确保存储和计算分离...这些字段类型,在 MySQL 数据库的检索性能不高,很难使用索引进行优化。如果必须使用这些功能,一般采取特殊的结构设计,或者与程序结合使用其他的字段类型替代。...数据库规范库表字段的命名,能够提高数据库的易读性,为数据库表设计打下基础。下面我们具体看看表设计的一些规则。 显式指定需要的属性; 创建表时显示指定字符集、存储引擎、注释信息等。

    3.3K12

    数据库篇:mysql表设计原则-三范式

    前言 关系型数据库的表在设计时,我们常常需要考虑哪些业务字段应该放哪张表,字段是否应该拆分,表与表之间该怎么关联。那有没有相应的规范或者原则来指导我们去设计表呢?...数据库设计三范式;三范式主要是解决表之间的关联关系,和字段冗余问题 关注公众号,一起交流,微信搜一搜: 潜行前行 第一范式 列都是不可再分,第一范式的目标是确保每列的原子性,每列都是不可再分的最小数据单元...符合第一范式的设计 ? 第二范式 首先满足第一范式,并且表中非主键列不存在对主键不依赖或者部分依赖,确保每个列都和主键相关。...第三范式 满足第二范式,并且表中的列不存在对非主键列的传递依赖,每列都和主键列直接相关,而不是间接相关 在成绩表里,爱好是依赖学生的,学生又是依赖主键ID,存在传递依赖应该提取出学生的个人信息为表。...欢迎指正文中错误 参考文章 mysql 数据库的设计三范式[1] Reference [1] mysql 数据库的设计三范式: https://www.cnblogs.com/xiaozengzeng/

    1.1K10

    【愚公系列】2022年01月 Mysql数据库-表结构和关系的设计

    文章目录 一、多表设计 1.一对一 2.一对多 3.多对多 二、其他表 1.中间表 2.临时表 一、多表设计 1.一对一 分析 人和身份证。一个人只有一个身份证,一个身份证只能对应一个人!...实现原则 在任意一个表建立外键,去关联另外一个表的主键 SQL演示 -- 创建db5数据库 CREATE DATABASE db5; -- 使用db5数据库 USE db5; -- 创建person...实现原则 在多的一方,建立外键约束,来关联一的一方主键 SQL演示 /* 用户和订单 */ -- 创建user表 CREATE TABLE USER( id INT PRIMARY KEY...临时表是放在系统数据库 tempdb中的,而不是当前数据库。 临时表分两种:本地临时表和全局临时表。 a.本地临时表 本地临时表是以#开头的,只对当前的数据库用户可见,而其他的用户是不可见的。...b.全局临时表 以“##”开头的,而且是对所有的用户都是可见,当你断开数据库实例连接时,只要还有别的系统项目在引用它,连着数据库,那么数据就存在,只有当别的系统也全部断开连接时,系统才会清除全局临时表的数据

    75630

    MySQL设计表规范

    规范总结 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用 MySQL 保留关键字【设计表后逐一排查】 所有表必须使用 Innodb 存储引擎,数据库和表的字符集统一使用...UTF8 所有表和字段都需要添加注释 禁止在数据库中存储图片,文件等大的二进制数据 【通常存储于文件服务器,数据库只存储文件地址信息】 优先选择符合存储需要的最小的数据类型【能用整型就不要用字符串...数据库基本设计规范 1....数据库和表的字符集统一使用 UTF8 兼容性更好,统一字符集可以避免由于字符集转换产生的乱码,不同的字符集进行比较前需要进行转换会造成索引失效,如果数据库中有存储 emoji 表情的需要,字符集需要采用...通常存储于文件服务器,数据库只存储文件地址信息 数据库字段设计规范 1.

    1.5K10

    MySQL大表设计

    存储大规模数据集需要仔细设计数据库模式和索引,以便能够高效地支持各种查询操作。...在面对数亿条数据,每条数据包含数百个字段的情况下,以下是我能想到的在设计数据库的时候需要注意的内容,不足之处欢迎批评指正:1....数据库设计表结构设计垂直分割:将大的表分割成多个相关性较小的表,以减少单个表的字段数量。这有助于提高查询效率和降低冗余。规范化:合理使用规范化,将重复数据抽取成独立的表,以减小数据冗余。...垂直分割对于一些很少使用的字段,可以考虑将其垂直分割到其他表中,只在需要时进行关联查询。6. 数据库参数调优调整数据库的参数,如缓冲池大小、连接池大小等,以适应大规模数据的存储和查询需求。...在设计时,充分了解数据的访问模式,根据查询的特点合理设计索引,通过适当的规范化和分区来优化存储结构,最终达到高效的查询和存储效果。我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

    18510

    MySQL - 库表设计之IP和TIMESTAMP的处理

    Pre MySQL - 高效的设计MySQL库表 设计指导思想和注意事项都梳理了一下,那来个小练习把 ---- TIMESTAMP 我们使用 MySQL 内置的函数(FROM_UNIXTIME(),UNIX_TIMESTAMP...()),可以将日期转化为数字,用 INT UNSIGNED 存储日期和时间 示例 时间 2020-08-17 22:22:22 与整数之间的转换,转化后数字是连续的,占用空间更小,并且可以使用索引提升查询性能...MySQL 数据库内置了两个 IP 相关的函数 INET_ATON()、INET_NTOA(),可以实现 IP 地址和整数的项目转换。...---- 总结 以高性能为目标,库表设计以范式为主,根据特殊业务场景使用反范式,允许必要的空间换时间。 规范数据库的使用原则,统一规范命名,减少性能隐患,减少隐式转换。...高性能表设计的原则:合适的字段、合适的长度、NOT NULL。 从不同角度思考 IP、timestamp 的转换,拓宽设计思路。 规范的命名可提高可读性,反范式设计可提高查询性能。

    54410

    Mysql实例 表设计

    二.设计表格 公司表 公司名称 公司编号(自增主键) 电话号码 A 1001 xx B 1002 xx 广告表 广告编号 有该广告的公司的编号(自增主键) 广告收费/点击一次 1 1001 2 2 1001...between 100000 and 199999; 最后做个计算即可 四.分析 表结构设置 目前有3张表,基本满足业务需求,但未来查询更多,需要重新设计主键位置,表结构。...当数据庞大,首当其冲的是点击表,可能一天有几万次记录写入,这张表将变得庞大,可以考虑将表根据月份进行拆分。...sql语句 刚才查询A公司需要交费多少,比较繁琐,需要操作多次,可以将sql语句进行优化,查看消耗时间是多少,找出最优的语句和方法。 其它功能 当前表除了基本的查询,还可以进行数据分析。...可以通过点击表,分析出当前这月哪个广告受欢迎,次数最多。这种可以去和公司商议,建议投放公司将这类广告放到更显眼位置,但费用增加。

    1.3K20

    MySQL中的表设计优化

    在MySQL数据库中,表设计的优劣同样对性能有非常重要的影响。本节将介绍表设计的优化方法,包括巧用多表关系、表结构设计优化和表拆分等。...巧用多表关系 在进行数据库表的设计时,应尽量满足三范式,而字段冗余存储是经常遇到的一个问题。...反范式设计的好处是减少了表的数目,从而减少了join操作及外码和索引的数目,但是可能带来数据的完整性问题。另外,反范式设计虽然能加快查询速度,但是对数据的修改却需要更多的成本。...因此,在进行反范式设计之前,一定要权衡利弊,充分考虑应用的数据存取需求及表的大小等因素。在实际应用场景中,经常根据实际需求,采用范式化和反范式化混用的方式来提高数据库的性能。...此时可以考虑拆表技术,以缓解单表的访问压力,提高数据库的访问性能。 拆表分为水平拆分和垂直拆分。

    20810

    mysql之MVCC 配置优化 数据库表设计(四)

    内存参数配置 数据库表设计 三大范式 MVCC(多版本并发控制) Multiversion concurrency control (版本并发控制):并发访问(读或写)数据库时,对正在事务内处理的数据做多版本的管理...常见配置的帖子 数据库表设计 三大范式 第一范式( 1NF): 字段具有原子性,不可再分。...所有关系型数据库系统都满足第一范式)数据库表中的字段都是单一属性的, 不可再分; 第二范式( 2NF): 要求实体的属性完全依赖于主键。...简而言之, 第三范式( 3NF)要求一个数据库表中不包含已在其它表中已包含的非主键信息。...过多的列影响转换和持久的性能 过分的满足第三范式化造成了太多的表关联 表的关联操作将带来额外的内存和性能开销 使用innodb 引擎的外键关系进行数据的完整性保证 外键表中数据的修改会导致Innodb

    1.1K20

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

    大家好,又见面了,我是你们的朋友全栈君 mysql 数据库表结构设计与规范 DDL(data difinition language)就是数据定义语言。...mysql中的各种系统关键字和命令名本身是不区分大小写的,命名规则如下: 可以自己命名的名字,称为标识符,包括:数据库名, 表名,字段名,视图名,函数名,过程名,变量名,用户名,等等。...关于单引号和反引号 反引号是为了区分MySQL的保留字和普通字符,其他例如SQL语句用双引号 MySQL中反引号,是以对象为单位的,表,或者库等,不能把a.name都括起来,而是应该`a`....,而这个名字就是不存在的 mysql数据库使用的一些规范 通常来讲,各个互联网公司的数据库分为5个数据库环境: dev : 开发环境, 开发可读写,可修改表结构; 常用的163的数据库表; 开发人员可以修改表结构...MySQL 5.5.3以后支持) 存储引擎使用InnoDB 变长字符串尽量使用VARCHAR VARBINARY 不在数据库中存储图片、文件 设计表的时候需要添加注释 单表数据量控制在

    2.4K40
    领券