如何更好的写数据库?如何数据库语句优化?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何更好的写数据库?如何数据库语句优化?相关的知识,希望对你有一定的参考价值。


在数据库表设计方面:

在设计数据库的时候我们总要设计一些冗余字段~~为啥呢?

我自己猜的~~

有一些查询,冗余字段可以帮助我们不需要去联多表查询~~

于是乎你就可以做一些冗余字段了 ~~ 比如说评论数量

虽然说评论数量是可以从评论表里算出来的(在评论时做个触发器也不错,少查询一个表)

~~~

设置删除状态字段:

尽量少用delete语句~~这个语句在操作的时候会锁表~~以后直接用update

况且如果使用这个语句也会对数据产生一些问题~~还是不要删了

~~~~~~~

字段上面最好不要用null做默认值~~

~~~~~

做合理的索引~大量的索引只会似的插入数据缓慢

~~~~

类型字段建议采用tinyint

字符类型如下解释

varchar内存占用率小

char效率高(固定大小的字符串最好用这个存)

主键大部分都喜欢用 int~~估计大家都没有过 无符号的int(因为主键是非负数~~用这个的话主键量可以达到2倍~~~23333333)

~~~~

mysql和redis结合:

举个栗子:

比如说点赞~~~这个是个频繁的操作~~频繁的有好多点赞狂~~2333333

把在redis中存储点赞信息:

返回json时再和文章数据做整合~~效率提高数倍

~~~~

尝试对一些经常不动的数据进行缓存处理~~

----------------------

在数据库语句方面:

在使用select语句的时候尽量多些字段,如果用*的话效率好低地说

查询数量的时候 尽量使用 count(1)这种样子

查询一条语句的时候最好在后面加上 limit 1 这样的话数据库查询到一条的话就停止了

~~~~~~

如何进行快速插入呢?

insert into user(name) values(‘m’);

insert into user(name) values(‘n’);

拼接成如下语句

insert into user(name) values(‘m’), (‘n’);

效率会翻好几倍

~~~~~~~

如果能用inner join尽量使用~~这个效率最高

--------如下是看别人的博客里的-------

在查询的时候尽量不要用到 null判断 这样会导致数据库不用索引~去全表扫描~~效率很低~~

应尽量避免在 where 子句中使用 != 或 <> 操作符,否则将引擎放弃使用索引而进行全表扫描~~~

应尽量避免在 where 子句中使用 or 来连接条件,如果一个字段有索引,一个字段没有索引,将导致引擎放弃使用索引而进行全表扫描~~~

select id from t where num=10 or Name = admin

可以这样查询:

select id from t where num = 10 union all select id from t where Name = admin

in 和 not in 也要慎用,否则会导致全表扫描,如:

select id from t where num in(1,2,3)

对于连续的数值,能用 between 就不要用 in 了:

select id from t where num between 1 and 3

很多时候用 exists 代替 in 是一个好的选择:

select num from a where num in(select num from b)

用下面的语句替换:

select num from a where exists(select 1 from b where num=a.num)

下面的查询也将导致全表扫描:

select id from t where name like ‘%abc%’

以上是关于如何更好的写数据库?如何数据库语句优化?的主要内容,如果未能解决你的问题,请参考以下文章

计算机专业研究生核心能力培养——如何更好的写代码

计算机专业研究生核心能力培养——如何更好的写代码

计算机专业研究生核心能力培养——如何更好的写代码

mysql:只用一条sql语句,如何查出一个表里,不同条件对应的数据条数

SQL 多选一个字段值只选一次 和多次从表里查询但查的字段较少 相比哪个性能更好?为啥?

如何在sql数据库表里加入新的一列(表里原有数据)