数学建模社区-数学中国
标题:
数据库结构的优化
[打印本页]
作者:
杨利霞
时间:
2020-4-24 18:13
标题:
数据库结构的优化
- j; F: N8 N/ j/ _% y
数据库结构的优化
- R" O2 J7 B3 E
1、选择合适的数据类型
4 b8 Z) K' J4 F% a. j* f' W) y5 R
数据类型的选择,重点在于“合适”二字,如何确定选择的数据类型是否合适了?
, P1 I. N4 k* r3 Y9 j6 y# D. ~! o
1、使用可以存下你的数据的最小的数据类型。(时间类型数据:可以使用varchar类型,可以使用int类型,也可以使用时间戳类型)
% l& O7 }; [+ G3 E7 o' Z6 U# ?2 I
2、使用简单的数据类型,int要比varchar类型在mysql处理上简单。(int类型存储时间是最好的选择)
+ E, `! I3 r7 u" b
3、尽可能的使用not null定义字段。(innodb的特性所决定,非not null的值,需要额外的在字段存储,同时也会增加IO和存储的开销)
, `. R `; |8 J0 ~- a9 j' `
4、尽量少用text类型,非用不可时最好考虑分表。
} o0 f+ \0 A! ~; P7 u) w
1 G" z4 ^% d. {9 G" ~" q& s3 n8 t
2、数据库表的范式化优化
_2 {- s, n4 U+ K( q2 h
范式化是指数据库设计的规范,目前说道范式化一般是指第三设计范式。也就是要求数据表中不存在非关键字段对任意候选关键字段的传递函数依赖则符合第三范式。
+ A7 p+ i3 {3 h |( ~7 E
& G5 \' z+ o' K
反范式化
) j( A" [+ P. X0 w: T0 ^( K4 u5 w
反范式化是指为了查询效率的考虑把原本符合第三范式的表“适当”的增加冗余,以达到优化查询效率的目的,反范式化是一种以空间来换取时间的操作。
" S W A4 @' C0 p/ v: S# p5 d9 D& H
3 f% H1 T# |: r2 g" i# g1 N
3、数据库表的垂直拆分
# x9 E# ]* \) H/ d+ l( g
垂直拆分定义
6 N+ m% B2 E2 T; }
所谓的垂直拆分,就是把原来一个有很多列的表拆分成多个表,这解决了表的宽度问题。
) `2 r+ V* Z4 {' n, z x
垂直拆分原则
r/ |# S) a3 }- O2 R: f
通常垂直拆分可以按以下原则进行:
$ b' d; e; S3 M; {6 p0 U
1、把不常用的字段表单独存放到一个表中。
' Y0 ~3 W4 D7 X! a
2、把大字段独立存放到一个表中。
% a1 ?4 ^. A8 e' l6 _! s
3、把经常一起使用的字段放到一起。
0 j( ?! k0 X* ^/ m u, y
+ C$ S/ q1 _8 N% P1 x5 I" h% ?
4、数据库表的水平拆分
4 C/ ]- u# M: D# q" Y/ T: z f! i
0 O. p* K3 a( G; `; a7 U
为什么水平拆分
# q6 ^+ ]" V$ w" x6 ^3 l
表的水平拆分是为了解决单表数据量过大的问题,水平拆分的表每一个表的结构都是完全一致的
2 m7 ^ T) E: R
. ^/ w3 s6 u* a' e: S! K: L
水平不拆分原因
/ B; h0 i8 j& A1 y2 J
如果单表的数据量达到上亿条,那么这时候我们尽管加了完美的索引,查询效率低,写入的效率也相应的降低。
/ F7 k1 l# p# S' _
5 v8 H6 |. ?6 N" y9 `9 ]' Z
如何将数据平均分为N份
; `# `' n) I. k0 J* }
通常水平拆分的方法为:
, d- a0 B% Z! m
1、对customer_id进行hash运算,如果要拆分为5个表则使用mod(customer_id,5)取出0-4个值。
" b' K7 A( j9 Q0 ?( z0 O
2、针对不动的hashid把数据存储到不同的表中。
; n1 T" n0 E, V- P$ L+ b0 X$ N* e: @
; R$ r9 \8 |/ Y9 b& s
水平拆分面临的挑战
$ f b/ k3 Y: z& B
! I# z& K& T( x& }
1、夸分区表进行数据查询
3 {0 F% S4 E, G! J& o
前端业务统计:
4 `* |) |5 e4 }
业务上给不同的用户返回不同的业务信息,对分区表没有大的挑战。
( J5 _+ m: i) F' a( l# b
2、统计及后台报表操作
1 W0 F. m: Y4 j9 l; K
但是对后台进行报表统计时,数据量比较大,后台统计时效性比较低,后台就用汇总表,将前后台的表拆分开。
! H @+ P7 [0 G1 k, d- \1 O7 b- V
————————————————
5 |8 j8 | d0 f* d. N ~
版权声明:本文为CSDN博主「Cgy25」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
, A1 t; |7 h5 u9 A! n1 q
原文链接:https://blog.csdn.net/Cgy25/article/details/105690070
( c5 d# y$ r, T, E9 I
$ W1 z( z% j& ]- X* A
8 V. ~) y8 X4 `" G% |
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5