当前位置:首页 > SQL > 正文内容

MySql基本的建表原则

高老师9年前 (2017-06-21)SQL1895

1.定长和变长的分离

 如int,char,time所占字节是固定的字段放在一张表

 如varchar,text所占字节不确定的字段放在一张表中

2.常用字段和不常用字段进行分离,根据查询频率来设计

3.一对多的关联表可以添加冗余字段,如商品分类表 和商品表 ,在首页中需要显示每个分类商品总数.解决方案1是left join查询,解决方案2是在商品分类表中增加字段来统计数量,每次增加商品+1,这样就避免关联表查询牺牲的性


4.字段类型的选择,整型 ->datetime->enum->char->varchar->text,优先定长类型,没有国家区分,无字符集的差异.整型的优势,例如tinyint 1 2 3 4和char a b c d e在order by 下前者速度快。如果是字符类型快考虑字符集和排序,影响性能

5.enum类型约束值的规范使用.在.net中经常使用enum.但是PHP中我还是很少的.enum('男','女'),内部会增加一个转换过程,转为数字来存

6.尽量避免使用Null,不利于索引

7.存储引擎选择,小型产品对数据不严格,采用MyISAM,插入速度快,移植快;大型项目对数据一致性,可用性要求比较高建议InnoDB,MEMORY类型选择我还是不建议的,还不如直接采用redis

8.精确浮点数使用DECIMAL替代FLOAT和DOUBLE,例如微擎人人商城系统中大幅度使用

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/292.html

分享给朋友:
返回列表

没有更早的文章了...

下一篇:mysql group分组排序

“MySql基本的建表原则” 的相关文章

Mysql exists型子查询

Mysql exists型子查询

需求查询出存在商品的商品分类.    先看看分类表:id(分类的id)    catename(分类名) 1         手机 2 &n...

mysql常用函数

mysql常用函数

1.floor(x)返回小于x的整数,向下取整,用法,商品的价格是浮点型的,需要向下取整 eg:select id,title,floor(price)  from  shopgoods2.rand()返回0-1之间的随机数 select rand() select rand()...

mysql全文检索,mysql使用全文索引,mysql5.7全文索引

mysql全文检索,mysql使用全文索引,mysql5.7全文索引

1.查看歌曲表结构(主要是给name字段添加全文索引)(mysql5.7才支持全中文索引)desc   music; +---------+-------------+------+-----+---------+----------------+ | Fie...

inner join 和 form a,b区别和速度

inner join 和 form a,b区别和速度

在项目中发现大量的form连接表,就开始质疑inner join 和 form a,b的性能问题。找到一份有价值的资料,特别记录:ANSI SQL规范首选INNER JOIN语法。此外,尽管使用WHERE子句定义联结的确比较简单,但是使用明确的联结语法能够确保不会忘记联结条件,有时候这样做也能影响性...

mysql 自定义排序,mysql 自定义字段排序,mysql 强制自定义排序

mysql 自定义排序,mysql 自定义字段排序,mysql 强制自定义排序

通常我们使用自定义排序的语法是:ORDER BY FIELD(`字段名称`, 值1, 值2, 值3),但是如果我想强制值1到值3永远在前面,这个语法是满足不了的.(1).基本的会员数据表:id      name  &n...

union合并多个SELECT语句的结果集

union合并多个SELECT语句的结果集

结果1:SELECT vend_id,prod_id,prod_price  FROM  products WHERE prod_price<=5结果2:SELECT vend_id,prod_id,prod_pr...