站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
建站程序
开发
服务器
办公软件
开发教程
服务器教程
软件使用教程
运营教程
热门电子书
WordPress教程
宝塔面板教程
CSS教程
Shopify教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
Hostmonster/优化MySQL
”
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
==优化你的MySQL== *了解一些做index(索引)的知识 允许你更有效地使用它们。首先,注意到当你使用索引更新表格时,索引也需要更新,这就有一个性能代价。除非你的系统运行的 inserts远多于selects,并且inserts 要很快速而selects不需要,这是一个值得的代价。 *如果你想选择多于一种标准会如何? (就像你所看到的,只对你在WHERE从句中使用的那些域作标记有效.)查询: *SELECT firstname FROM employee; 没有使用索引。 对firstname的索引无效. *但是SELECT firstname FROM employee WHERE surname="Madida"; 将能从surname的索引获得好处。 *让我们看一写更复杂的例子,可以帮助我们提升查询。我们想要找到加班费率的一半低于20美元的员工。得知要做什么,你正确地给 overtime_rate做了标记, 看成where从句里的 column 。 ALTER TABLE employee ADD INDEX(overtime_rate); ==运行查询== <pre> EXPLAIN SELECT firstname FROM employee WHERE overtime_rate/2<20; +----------+------+---------------+------+---------+------+------+------------+ | table | type | possible_keys | key | key_len | ref | rows | Extra |<br> +----------+------+---------------+------+---------+------+------+------------+ | employee | ALL | NULL | NULL | NULL | NULL | 2 | where used |<br> +----------+------+---------------+------+---------+------+------+------------+ </pre> *每一份员工的单个记录都被读取,为什么这样? 问题出在查询的"overtime_rate/2" 部分. 每一个 overtime_rate (因此就是每一个记录)都必须被读取以被2分开。所以我们应该尝试不管编入索引的区域, 不需要进行任何计算。 这如何可能? 这就要用到学校里学的代数了! 你知道 'x/2 = y' 等价于 'x = y*2'.我们重写查询,看overtime_rate是否少于20*2,结果发生了什么. <pre> EXPLAIN SELECT firstname FROM employee WHERE overtime_rate<20*2; <br> +--------+-------+---------------+---------------+---------+------+------+----------+ |table | type | possible_keys | key | key_len | ref | rows |Extra |<br> +--------+-------+---------------+---------------+---------+------+------+----------+ |employee| range | overtime_rate | overtime_rate | 4 | NULL | 1 |where used| +--------+-------+---------------+---------------+---------+------+------+----------+ </pre> *MySQL 进行一次 20*2运算, 然后在索引里搜索该常量. 这里的法则是,保证索引区域与比较部分分离,这样 MySQL 可以用其来搜索,而不需要进行计算。. *你可能会说我耍小聪明,应该这样表达请求:" overtime rate 低于40的部分",但是用户似乎有使用最坏的方式表达请求的习惯! ==参考来源== *http://kb.idcspy.org/HostMonster%E7%9F%A5%E8%AF%86%E5%BA%93 *http://www.databasejournal.com/features/mysql/article.php/10897_1382791_2 [[category:HostMonster|Z]]
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)