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

WBOY
Release: 2016-06-13 12:15:20
Original
942 people have browsed it

处理大数据高并发问题
在数据库里面
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),散列到不同的数据库表中。

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!