处理大数据高并发有关问题

WBOY
풀어 주다: 2016-06-13 12:15:20
원래의
942명이 탐색했습니다.

处理大数据高并发问题
在数据库里面
database  
   A
  表有1张
   a
 里面数据为
 firstname   lastname 
  A          a
   这样表里面有百万级的数据。
于是问题就来了
 /*前面的$name已经是我已经定义了的*/
$result= "SELECT lastname FROM  a WHERE firstname='".$name."'";  
$sql_name=mysql_query($result);
$name=mysql_fetch_array($sql_title);
$subject =$name[0];
?>
于是问题就来了
服务器一处理同时500个并发数据库就挂了。
有啥好办法解决吗?

   

  
------解决思路----------------------
很遗憾,这是你的硬件和操作系统不支持你那么高的并发。
仅从 php 角度是不能改变现状的
对于你的代码:
在 php 层面没有任何优化的余地
在 mysql 层面,也只是对 firstname 列做索引而已

------解决思路----------------------
$result= "SELECT lastname FROM  a WHERE firstname='".$name."'";

$result= "SELECT lastname FROM  a WHERE firstname='".$name."' limit 0,1";
意义是不同的!

前者表示可能取出多行
后者表示无论多少行都只取遇到的第一行

如果为了所谓的速度,连本意都扭曲了。那“优化”有什么意义?
------解决思路----------------------
通过横向或纵向分表,或者通过多数据库分压的方式。

------解决思路----------------------
我表示分库分表吧。。。
md5(firstname+lastname),散列到不同的数据库表中。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!