当前位置:首页百负载之SQL数据库的优化 举报文章

百负载之SQL数据库的优化

作者:admin    来源:用户投稿    时间:2015.6.11   

  在考虑一个网站如果承载日百甚至千pv时,我们往往本能的往两个方向考虑:静态化及分布式。 固然,对于新浪等门户类型的网站来说,静态化+读写分离及分布式,可以解决大多数的问题。可是我们面临的更多的,可能是大数据+高并发+实时读取,而静态化的固定性便很难解决这个问题。

  比如矮个芝麻最近接到的一个电子商务类的网站,流量大,数据量大,同时要求实时更新,因为首页以及内容页往往每时每刻都在变化着。 这个时候我们就不得不查询数据库,也就需要针对数据库作出一些特定的优化。

  优化建议:

  1)表结构的优化

  通过对表结构的优化,往往可以直接的降低数据库的压力。常见的方法比如建索引,拆表,适当冗余扁平化。 索引的作用最为直接,通过B+树轻松实现类似于将一张表划分为几百张表的效果,在进行查询时,往往链表查询需要十次才能查询到的数据,加了索引之后或许只需要四次就可以解决。

  当然不要过分的增加索引,因为会一定程度上增加数据库的负担。 同时说一个很有意思的问题,如何实现身份证查询系统?我们往往知道,身份证的前几位决定了这个人的所在地,出生年月等可见信息,然后才是几位随机数。而且应该有发现一个问题,那就是只有在户口所在地才能登记身份证,这就是拆表查询。公安系统只需要查询当地数据库下该生日及随机数是否有重复,就可以判断全国是否有重复的身份证了。

  最常用的方法是,将一个月内的活跃用户单独设为一个表,这样每次用户登录,其实只是查询了当月的用户,可以有效的提高查询效率.

  2)sql语句的优化

  sql语句的优化往往要直白很多,就是尽量减少like查询,关联查询等资源消耗比较大,查询量比较大的sql语句,即可,整理了几条如下:

  1.减少不必要的like查询,尽量通过建关键词表实现like查询的效果

  2.减少关联查询,尽量通过左链接右链接的形式实现查询

  3.复杂的查询语句使用储存过程解决.

  4.减少不必要的查询.

  5.避免在索引列上使用IS NULL和IS NOT NULL

  6.尽量避免使用耗费资源的操作:带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎

  7.不要使用SELECT *,尽量指明要显示的列

  8.不要使用INSERT导入大批的数据 请不要这样做,除非那是必须的。使用UTS或者BCP,这样你可以一举而兼得灵活性和速度。

  3)程序段的优化尤为重要

  程序段根据不同的用户需求进行优化,尤为重要.

  最常见的案例就是,当查询列表时,只查询出标题名及简介就可以解决问题.当用户打开该文章后,才会查询该文章的文章内容,评论,发表人信息等关联表的内容.这样可以在很大程度上降低程序的负担.

  尽量通过ajax,在有必要的情况下进行后台查询,而不是在打开页面的时候就进行相关的查询.

  另外,最为重要的一点就是,尽量实现静态化.

  一般对于cms类型的网站来说,静态化可以解决大多数的问题.而后需要查询数据库的无非就是搜索,用户会员中心的相关操作.

  而搜索是可以通过读写分离异步操作的,这样就可以有效的降低服务器的压力.

  当然,还有更多更有效的方法,只是今天突然兴起整理一下,有问题可以和矮个芝麻一起沟通哦~

好文打赏,给Ta鼓励
扫一扫用手机阅读本文
Tags:百万  负载  数据  数据库  优化  
  • 相关搜索
图片推荐
    许知远:这个时代的创业风气未免把人的价值贬低化了

    许知远:这个时代的创业风气未免把人的价值贬低化了

    单向街从来都是内容创业者。诚如许知远所言,单向街一直是靠思考和表达立足的。  不过单向街却是内容创业者中非常独特的一个。无论是书店,出版,做音频、做视频,甚至一年比一年火爆的单向历,都传达着属于单向街
    在苹果的春节广告中 李宗盛唱起了“恭喜恭喜恭喜你”

    在苹果的春节广告中 李宗盛唱起了“恭喜恭喜恭喜你”

    苹果要让李宗盛《送你一支新年歌》。    恭喜恭喜  春节将至,不老天王刘德华恭喜发财的歌声是不是又要传遍大街小巷?不过今年,你还会听到另一个版本,苹果请来了另一位华语歌坛教父李宗盛来重新演绎了这首歌
    阿里京东互进对方后院:两大电商的自由与尴尬

    阿里京东互进对方后院:两大电商的自由与尴尬

    面对这样一幕,京东创始人刘强东的心理也许很复杂吧:昨日,淘宝跑到江苏沐阳,牵手与当地政府,将帮助化解当地优势花木产业电商化进程中的诚信问题。双方为此专门成立一个1000万元的诚信保障基金,主要解决当地
    【观察】微商模式到底是进步还是退步?

    【观察】微商模式到底是进步还是退步?

    题记:在我的印象里,不管是线上的互联网企业,还是线下的传统企业,任何一个做大的公司,在创业期甚至是创业前期的很长一段时间内,都是靠几个核心人员甚至是老板本人通过跑业务最终才打下的江山。  从2014年
    微信7.0最大的变化,你发现了吗

    微信7.0最大的变化,你发现了吗

    此前iOS微信正式更新了7.0.0版,整个界面UI变了样同时增加“时刻视频”等一系列重磅功能。新版本里公众号的“点赞”按钮变成“好看”,用户能在“看一看”里浏览朋友认为好看的文章;并且在聊天详情页中,
    不要让微信成了广告集中营

    不要让微信成了广告集中营

    最近微信集赞活动开展得如火如荼,几乎每天打开微信都会收到帮我集个赞、帮我赞一下之类的朋友私信消息,一般情况下我也会顺便去帮助点一下赞。但是一段时间过后,发现朋友圈集赞现象越来越频繁,有时候甚至一打开微
你是怎么知道非凡网赚网的?
  •   
  • 联系QQ 邮箱:976382653@qq.com 微信:976382653
    在线留言
    发布软文
    广告自助购
    文章调用
    常见问题
    保存到桌面