成都网站建设之网站数据库优化

2024-01-21    分类: 网站建设

随着成都网站建设网站的使用时间越来越久,网站数据的存储量越来越大,服务器的性能需要更好地去优化,才能保证网站更优秀地运行。近日,我们在网上找了好多关于SQL优化的教程,感觉这篇教程讲的很详细,效果更为明显。现在推荐给大家,大家一起学习,一起进步。

成都网站建设

网上关于数据库优化的教程有很多,但是又多又乱的。最近因为服务器需要优化一下,所以从网上整理了一些,写出来跟大家分享一下,有什么不对和不足的地方,还请大家纠正补充。这篇文章我花费了大量的时间查找资料、修改、排版,希望大家阅读之后,感觉好的话推荐给更多的人,让更多的人看到、学习、纠正补充。

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

selectid fromt wherenum=10orName ='admin'

可以这样查询:

selectid fromt wherenum = 10

unionall

selectid fromt whereName ='admin'

2.尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如:

selectid fromt wherenum isnull

最好不要给数据库留NULL,尽可能的使用NOT NULL填充数据库.

备注、描述、评论之类的不重要的可以设置为NULL,其他的,最好不要使用NULL。不要以为NULL 不需要占用空间,比如:char(100) 型,在字段建立时,空间就固定了,不管是不是插入值(NULL也包含在内),都是占用100个字符的空间的,如果是varchar这样的变长字段,null 不占用空间。可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:

selectid fromt wherenum =0

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

4.适当的时候应该考虑在where 及 order by 涉及的列上建立索引。以提高查询速度。

5.下面的查询也会导致全表扫描:

selectid fromt wherename like‘%abc%’

若要提高效率,可以考虑全文检索的哦。

6.in 和 not in 也要慎用,否则也会导致全表扫描。

7.应尽量避免在where子句中对字段进行函数操作,这将导致引擎放弃使用索引,而进行全表扫描。如:

selectid fromt wheresubstring(name,1,3) = ’abc’ -–name以abc开头的id

selectid fromt wheredatediff(day,createdate,’2005-11-30′) = 0 -–‘2005-11成都网站建设之网站数据库优化
URL地址:/news42/314742.html

成都网站建设公司_创新互联,为您提供营销型网站建设网站改版微信小程序网站营销外贸建站微信公众号

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站优化排名