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

新零售mysql设计 订单 订单详情

作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人) 阿里云专家博主 文章目录 sql 订单 数据 订单详情 数据: 订单号与流水号有什么不同?...order_id int unsigned not null COMMENT "订单id", sku_id int unsigned not null COMMENT "商品id", 订单与商品的关系...一个订单可以包括多个商品 sql 订单 create table t_order( id int unsigned PRIMARY KEY AUTO_INCREMENT COMMENT "主键",...订单号是跟业务相关的,流水号是跟交易相关的,订单里面一定保存了金额,支付的时候用到流水号,所以两个使用的场景不一样,数据库id没有任何意义,只是一个记录的唯一标识而已 订单(解析) create table...别人看懂这是什么字段或者或者数据库 为什么要用int unsigned类型呢? 因为id是不是整数的。

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

MySQL数据库设计规范

一、数据库设计 1、一般都使用 INNODB 存储引擎,除非读写比率<1%,才考虑使用 MYISAM 存储引擎;其 他存储引擎请在 DBA 的建议下使用。...二、数据库对象设计规范 1、 设计 a)在设计时尽量包含两个日期字段:crt_time(创建日期),upd_time(修改日期)且 非空, 对表的记录进行更新的时候,必须包含对 upd_time字段的更新...d)Mysql尽量设置成 KV(Key-Value)结构,这样便于扩展和维护。 e)当的字段数非常多时,可以将分成两张,一张作为条件查询,一张作为详细内容(主要是为了性能考虑)。...h)由于MYSQLDDL维护成本很高,所以在适当的时候,可以有一定的字段容余。 比如:Value1,Value2,Value3 这样的字段。...e) 外键约束一般不在数据库上创建,只表达一个逻辑的概念,由程序控制。 f) 当万不得已必须使用外健的话,必须在外健列创建 INDEX。

2.8K30

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

一个成熟的数据库架构并不是一开始设计就具备高可用、高伸缩等特性的,它是随着用户量的增加,基础架构才逐渐完善。...二.数据库设计 项目立项后,开发部门根据产品部门需求开发项目。开发工程师在开发项目初期会对表结构设计。对于数据库来说,结构设计很重要,如果设计不当,会直接影响到用户访问网站速度,用户体验不好!...6.保证每张都有一个主键ID 每设计新建一张的时候,都应该为其设计一个ID字段,并让其成为主键,而且最好是INT型(也有使用UUID的),同时设置这个ID字段为自增(AUTO_INCREMENT)的标志...16.避免多表查询字段类型不一致 在遇到需要多表联合查询的时候,设计结构的时候,尽量保持的关联字段一致,并且都要设置索引。同时,多表连接查询时,尽量把结果集小的作为驱动。...17.建议开启查询缓存 大多数的MySQL服务器都开启了查询缓存,这是提高性能最有效的方法之一,因为查询缓存由MySQL数据库引擎自动处理,当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中

2.3K10

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

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

1.1K10

MySQL设计

存储大规模数据集需要仔细设计数据库模式和索引,以便能够高效地支持各种查询操作。...在面对数亿条数据,每条数据包含数百个字段的情况下,以下是我能想到的在设计数据库的时候需要注意的内容,不足之处欢迎批评指正:1....数据库设计结构设计垂直分割:将大的分割成多个相关性较小的,以减少单个的字段数量。这有助于提高查询效率和降低冗余。规范化:合理使用规范化,将重复数据抽取成独立的,以减小数据冗余。...分库分如果数据量仍然巨大,可以考虑分库分策略,将数据划分到不同的数据库中。4. 数据分区根据时间、范围等条件对数据进行分区,以提高查询效率。5....-- 例子:设置缓冲池大小SET GLOBAL innodb_buffer_pool_size = 2G;设计大规模数据集的数据库是一个综合性的任务,需要考虑到数据结构、索引、查询需求以及数据库引擎的特性

15210

Mysql实例 设计

二.设计表格 公司 公司名称 公司编号(自增主键) 电话号码 A 1001 xx B 1002 xx 广告 广告编号 有该广告的公司的编号(自增主键) 广告收费/点击一次 1 1001 2 2 1001...3 3 1002 2 点击 广告编号 该广告发送给浏览者的日期 1 101101 2 101102 1 101323 3 111232 三.查询 查都有哪些公司 直接查询公司的 公司名称 字段...select 公司名称 from 公司; 结果为A,B公司投放了广告 查A公司都放了哪些广告 先到公司,将公司名称=A的编号提取出来,然后将公司编号作为条件去广告表里找广告编号。...between 100000 and 199999; 最后做个计算即可 四.分析 结构设置 目前有3张,基本满足业务需求,但未来查询更多,需要重新设计主键位置,结构。...当数据庞大,首当其冲的是点击,可能一天有几万次记录写入,这张将变得庞大,可以考虑将根据月份进行拆分。

1.3K20

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

内存参数配置 数据库设计 三大范式 MVCC(多版本并发控制) Multiversion concurrency control (版本并发控制):并发访问(读或写)数据库时,对正在事务内处理的数据做多版本的管理...innodb_lock_wait_timeout InnoDB事务在被回滚之前可以等待一个锁定的超时秒数 https://www.cnblogs.com/wyy123/p/6092976.html 常见配置的帖子 数据库设计...所有关系型数据库系统都满足第一范式)数据库中的字段都是单一属性的, 不可再分; 第二范式( 2NF): 要求实体的属性完全依赖于主键。...简而言之, 第三范式( 3NF)要求一个数据库中不包含已在其它中已包含的非主键信息。...简单一点 : 1 , 每一列只有一个单一的值 ,不可再拆分 2 , 每一行都 有主键能进行区分 3 , 每一个都不包含其他已经包含的非主键 充分的满足第一范式设计将为建立太量的列 数据从磁盘到缓冲区

1K20

mysql 数据库结构设计与规范

大家好,又见面了,我是你们的朋友全栈君 mysql 数据库结构设计与规范 DDL(data difinition language)就是数据定义语言。...,而这个名字就是不存在的 mysql数据库使用的一些规范 通常来讲,各个互联网公司的数据库分为5个数据库环境: dev : 开发环境, 开发可读写,可修改结构; 常用的163的数据库; 开发人员可以修改结构...5.5.3以后支持) 存储引擎使用InnoDB 变长字符串尽量使用VARCHAR VARBINARY 不在数据库中存储图片、文件 设计的时候需要添加注释 单数据量控制在...、字段名禁止使用保留字 库名、名、字段名、索引名使用小写字母,以下划线分割 ,需要见名知意 库名、名、字段名、索引名不要设计过长,禁止超过32个字符,尽可能用最少的字符表达出的用途...充分利用前缀索引 尽量不使用存储过程、触发器、函数等,让数据库做最擅长的事 避免使用大的JOIN,MySQL优化器对join优化策略过于简单 避免在数据库中进行数学运算和其他大量计算任务

2.2K40

mysql设计规范

255(无符号)储存布尔值、状态、标志等具有低范围值的数据smallint2 字节有符号整数,取值范围为 -32,768 到 32,767 或者 0 到 65,535(无符号)储存较小的整数值,如年份、订单数量等...尽可能使用 not null定义字段将字段设置成空字符串或者常量值not null防止出现空指针的问题null值存储也需要额外的空间,导致比较运算更为复杂,是优化器难以优化sqlnull值可能会导致索引失效设计索引有查询条件的字段...,一般要加索引单的索引不超过5个区分度不高的字段,不添加索引(性别)避免索引失效的情况(mysql的内置函数)索引过多,选用联合索引优化不使用外键关联使用外键存在性能问题、并发死锁问题、使用起来不方便等...每次delete、update都必须考虑外键约束分库分不能使用不建议使用存储过程、触发器存储过程:已预编译为一个可执行过程的一个或多个sql语句触发器:一段代码,当触发某个事件时,自动执行这些代码可以用数据库中相关联的实现级联修改实现监控某张中的某个字段的改变而需要做出相应的处理生成某些业务的编号滥用造成数据库和应用程序的维护困难...mysql对于存储过程、触发器等还不是很成熟,没有完善的出错记录处理,不建议使用sql编写的优化经验查询尽量不要使用select *查询的结果只要一条或者只要最大/小的一条记录,建议使用limit 1避免

21330

MySQL的物理设计

设计结构之后, 就需要进行物理设计, 将实体及属性映射到具体表和列. 而合理选择存储引擎和列类型也是数据库设计十分重要的一个环节....物理设计包括, 命名规范, 存储引擎, 列字段选择, 主键设计以及主键生成算法. 一. 命名规范 首先在定义数据库,,字段时一定要公司的命名规范; 二....在加载同样数据时, 需要加载的数据页也就越少, 也就能减少磁盘IO, 提高数据库性能. 3.1 整数类型 根据业务情况, 选择合适类型 类型 大小 有符号范围 无符号范围(unsigned) tinyint...如存储金钱相关数据, 那最好是decimal类型 列类型 存储空间 是否精确类型 float 4字节 否 double 8字节 否 decimal 每4字节存9个数字,小数点占1个字节 是 3.3 字符串类型 MySQL...主键选择 应选择尽可能小且顺序增长的数字类型, 并且主键可以与业务主键不同.

1.2K10

MySQL - 高效的设计MySQL

范式与反范式 范式 范式是关系数据库理论的基础,也是我们在设计数据库结构过程中所要遵循的规则和指导方法。数据库设计范式是数据库设计所需要满足的规范。...---- 设计符合 2NF 的订单信息为例,讲述如何设计一个符合 2NF 的 首先,我们看原始的订单信息,如下图所示 ?...应该对订单信息进行拆分,商品信息单独一张订单项目一张,如下所示,拆分分成 3 张。...包含客户信息的订单信息 包含商品详情的商品信息 包含订单详情的订单详情 ---- 范式优缺点 【优点 】 避免数据冗余,减少维护数据完整性的麻烦; 减少数据库的空间;...数据库规范库表字段的命名,能够提高数据库的易读性,为数据库设计打下基础。下面我们具体看看表设计的一些规则。 显式指定需要的属性; 创建时显示指定字符集、存储引擎、注释信息等。

3.2K12

常见电商项目的数据库设计(MySQL版)

常见电商项目的数据库设计(MySQL版) 简介: 目的: 电商常用功能模块的数据库设计 常见问题的数据库解决方案 环境: MySQL5.7 图形客户端,SQLyog Linux 模块: 用户:注册、登陆...商品:浏览、管理 订单:生成、管理 仓配:库存、管理 电商实例数据库结构设计: 电商项目用户模块 用户涉及的实体 改进1:第三范式:将依赖传递的列分离出来。...ARCHIVE 5.分区数据归档迁移条件 6.操作步骤   mysql >= 5.7   结构相同   归档到的数据一定是非分区   非临时;不能有外键约束   归档引擎要是:archive...; DB规划 为以后数据库迁移提供方便 避免跨库操作,把经常一起关联查询的放到一个DB中 为方便识别所在的DB,在名前增加库名前缀 用户数据库(mccustomerdb) customerinf...) productinfo productpicinfo productcategory productsupplierinfo productcomment productbrandinfo 订单数据库

1.8K30

常见电商项目的数据库设计MySQL版)

简介: 目的: 电商常用功能模块的数据库设计 常见问题的数据库解决方案 环境: MySQL5.7 图形客户端,SQLyog Linux 模块: 用户:注册、登陆 商品:浏览、管理 订单:生成、管理 仓配...:库存、管理 电商实例数据库结构设计 电商项目用户模块 用户涉及的实体 ?...ARCHIVE 分区数据归档迁移条件 操作步骤 mysql >= 5.7 结构相同 归档到的数据一定是非分区 非临时;不能有外键约束 归档引擎要是:archive 使用分区的注意事项 结合业务场景选择分区键...; DB规划 为以后数据库迁移提供方便 避免跨库操作,把经常一起关联查询的放到一个DB中 为方便识别所在的DB,在名前增加库名前缀 用户数据库(mccustomerdb) customerinf...数据库设计及架构优化 电商项目,sqlercn,https://coding.imooc.com/class/79.html

48.9K2012

MySQL 数据库分区.

MySQL 数据库在 5.1 版本时添加了对分区(partitioning)的支持。分区的过程是将一个或索引分解成多个更小、更可管理的部分。...MySQL 数据库支持的分库类型为水平分区(指将同一中不同行的记录分配到不同的物理文件中),并不支持垂直分区(指将同一中不同列的记录分配到不同的物理文件中)。...MySQL 数据库的分区是局部分区索引,一个分区中既存放了数据又存放了索引。而全局分区是指,数据存放在各个分区中,但是所有数据的索引放在一个对象中。MySQL 数据库目前不支持全局分区。...MySQL 查看数据库分区。 SHOW VARIABLES LIKE '%partitions%'; MySQL 数据库支持以下几种类型的分区。...我们通过 Navicat 来操作下数据库分区, -> 右键点击'设计' -> 选项 -> 分割区,可以看到如下内容。 ? 来看看分区后,磁盘中 MySQL 数据库是怎么存储的。 ?

9.1K20

MySQL 搭建数据库

创建MySQL数据需要以下信息: 名 表字段名 定义每个表字段 语法 以下为创建MySQL数据的SQL通用语法: CREATE TABLE table_name (column_name column_type...); 以下例子中我们将在 RUNOOB 数据库中创建数据runoob_tbl: CREATE TABLE IF NOT EXISTS `runoob_tbl`( `runoob_id` INT...---- 通过命令提示符创建 通过 mysql> 命令窗口可以很简单的创建MySQL数据。你可以使用 SQL 语句 CREATE TABLE 来创建数据。...实例 以下为创建数据 runoob_tbl 实例: root@host# mysql -u root -p Enter password:******* mysql> use RUNOOB; Database...使用PHP脚本创建数据 你可以使用 PHP 的 mysqli_query() 函数来创建已存在数据库的数据。 该函数有两个参数,在执行成功时返回 TRUE,否则返回 FALSE。

10.4K10

Oracle数据库 连接与设计

用于定位数据库中一条记录的一个 相对唯一地址值。通常情况下,该值在该行数据插入到数据库时即被确定且唯一。 ROWID 它是一个伪列,它并不实际存在于中。...数据库的大多数操作都是 通过 ROWID 来完成的,而且使用 ROWID 来进行单记录定位速度是最快的。我们可以将其用于删除重复数据。...在数据库中索引可以减少数据库程序查询结果时需要读取的数据量,类似于在书籍中我们利用索引可以不用翻阅整本书即可找到想要的信息。...create index idx_emp on emp(sal,ename); drop index idx_emp; select * from emp order by sal,ename; ---- 三、设计...设计首先应该按需遵循三范式 --之间的关系: 一对一 一对多|多对一(主外键) 多对多{中间} -- 名 字段 约束 之间的关系

2.1K20
领券