SlideShare ist ein Scribd-Unternehmen logo
1 von 24
Downloaden Sie, um offline zu lesen
PHP	
  +	
  MySQL	
  

Optimization	
  
Introduction
•  The report includes project-related (EU) queries, tables
or databases example.
•  We can learn simple php/mysql optimization.
•  Know the main idea of using index in a table.
Let’s start from simple
cases
Let’s start from simple
cases
Avoid excess variables
function	
  isSomething()	
  
{	
  
	
  	
  	
  	
  	
  	
  	
  	
  $is_something	
  =	
  false;	
  
	
  	
  	
  	
  	
  	
  	
  	
  	
  if	
  ($some_condition_happens)	
  {	
  
	
  	
  	
  	
  	
  	
  	
  	
  	
  	
  	
  	
  	
  $is_something	
  =	
  true;	
  
	
  	
  	
  	
  	
  	
  	
  	
  	
  }	
  
	
  
	
  	
  	
  	
  	
  	
  	
  	
  	
  return	
  $is_something;	
  
}	
  
Let’s start from simple
cases

Use cache
(eg. APC, memcache)
Let’s start from simple
cases

Avoid queries inside a loop.
$player_ids = array(1, 2, 3, 4, 5, 6, 7, 8);
foreach ($player_ids as $id) {
$players_infos[] = $db->query(“SELECT * FROM player WHERE id = ?”,
array($id));
}
Let’s start from simple
cases

Select only needed columns.
Let’s start from simple
cases

count(*) vs count(col_name)
Let’s start from simple
cases

limit 1 when retrieving a
unique row.
Index to remember
Index to remember

Without an index, MySQL must begin
with the first row and then read
through the entire table to find the
relevant rows.
Index to remember
If there is a choice between multiple
indexes, MySQL normally uses the
index that finds the smallest number
of rows
Index to remember
To retrieve rows from other tables
when performing joins, MySQL can
use indexes on columns more
efficiently if they are declared as the
same type and size.
(Comparison of dissimilar columns may prevent use of
indexes if values cannot be compared directly without
conversion.)
Index to remember
“Index has significant cost. So you should not
create index everywhere.”
- http://lab.klab.org/
mysql-bootcamp/key.html
Examples
Examples
Scenario : Imagine you have a table that will
store millions of records (eg. item_history)
and you don’t have indexes.
Examples
The table structure :
id
int(10) unsigned
player_id
unsigned
item_master_id
unsigned
type
enum('INC','DEC')
reason

int(10)
int(10)
Examples
The problem : When you try to select data
from a table without index

See how many rows were checked after the search?
Examples
The solution : We are going to add index for the player_id
column
ALTER TABLE `item_history` ADD INDEX ( `player_id` )

See the advantage of adding an index?
The search took 1 row search only.
Examples
Upon looking on the table structure
which column/s can be used as index
when you want to retrieved a player’s
item history?
Exercise
Table Name : unit_history
Description : Tracks player’s record when he/she gained, evolved,
etc.. a unit.
Table structure :
id
player_id
unit_master_id
type
‘ITEM’)
created

int(10)
int(10)
int(10)
enum(‘INC’, ‘DEC’, ‘EVOLVED’, ‘EXP’,
timestamp
Exercise
The Scenario :
List player ids who gained and evolved the unit
id 10
The Question :
What are the possible index we might need in
order to retrieve the data faster.
Using index in joins

•  columns that you will use as the join
• 
• 

condition ( ON a.id = b.id ) should be
indexed.
LEFT JOIN will use indexed column from left
( a.id )
RIGHT JOIN will use indexed column from
right ( b.id )
Did you know?
That we MySQL has a built-in profiling tool?
SET PROFILING = 1;
SELECT COUNT(*) FROM table_name WHERE id = 1;
SHOW PROFILE FOR QUERY 1;
SHOW PROFILES;

Weitere ähnliche Inhalte

Ähnlich wie Php + MySql Optimization

Database development coding standards
Database development coding standardsDatabase development coding standards
Database development coding standards
Alessandro Baratella
 
Sql query tips or query optimization
Sql query tips or query optimizationSql query tips or query optimization
Sql query tips or query optimization
Vivek Singh
 

Ähnlich wie Php + MySql Optimization (20)

15 Ways to Kill Your Mysql Application Performance
15 Ways to Kill Your Mysql Application Performance15 Ways to Kill Your Mysql Application Performance
15 Ways to Kill Your Mysql Application Performance
 
MySQL for beginners
MySQL for beginnersMySQL for beginners
MySQL for beginners
 
Mysql Optimization
Mysql OptimizationMysql Optimization
Mysql Optimization
 
Database Performance Tuning
Database Performance Tuning Database Performance Tuning
Database Performance Tuning
 
Database development coding standards
Database development coding standardsDatabase development coding standards
Database development coding standards
 
Less08_Schema Advanced Databases and Management.pptx
Less08_Schema Advanced Databases and Management.pptxLess08_Schema Advanced Databases and Management.pptx
Less08_Schema Advanced Databases and Management.pptx
 
MySQL Performance Optimization
MySQL Performance OptimizationMySQL Performance Optimization
MySQL Performance Optimization
 
My SQL Skills Killed the Server
My SQL Skills Killed the ServerMy SQL Skills Killed the Server
My SQL Skills Killed the Server
 
Sql killedserver
Sql killedserverSql killedserver
Sql killedserver
 
Cs341
Cs341Cs341
Cs341
 
Sql query tips or query optimization
Sql query tips or query optimizationSql query tips or query optimization
Sql query tips or query optimization
 
SQL Server Select Topics
SQL Server Select TopicsSQL Server Select Topics
SQL Server Select Topics
 
Postgresql Database Administration Basic - Day2
Postgresql  Database Administration Basic  - Day2Postgresql  Database Administration Basic  - Day2
Postgresql Database Administration Basic - Day2
 
Data Structure In C#
Data Structure In C#Data Structure In C#
Data Structure In C#
 
MySQL Indexes
MySQL IndexesMySQL Indexes
MySQL Indexes
 
Indexing Strategies
Indexing StrategiesIndexing Strategies
Indexing Strategies
 
Lecture 9.pptx
Lecture 9.pptxLecture 9.pptx
Lecture 9.pptx
 
Database Application for La Salle
Database Application for La SalleDatabase Application for La Salle
Database Application for La Salle
 
Chapter 1 - Introduction to Data Structure.ppt
Chapter 1 - Introduction to Data Structure.pptChapter 1 - Introduction to Data Structure.ppt
Chapter 1 - Introduction to Data Structure.ppt
 
Module 3
Module 3Module 3
Module 3
 

Mehr von KLabCyscorpions-TechBlog

Mehr von KLabCyscorpions-TechBlog (12)

Object Calisthenics in Objective-C
Object Calisthenics in Objective-CObject Calisthenics in Objective-C
Object Calisthenics in Objective-C
 
Auto Layout on Xcode 5
Auto Layout on Xcode 5Auto Layout on Xcode 5
Auto Layout on Xcode 5
 
Code Review for iOS
Code Review for iOSCode Review for iOS
Code Review for iOS
 
Object Calisthenics
Object CalisthenicsObject Calisthenics
Object Calisthenics
 
Why You're A Bad PHP Programmer
Why You're A Bad PHP ProgrammerWhy You're A Bad PHP Programmer
Why You're A Bad PHP Programmer
 
Redis Set Go
Redis Set GoRedis Set Go
Redis Set Go
 
Redis Beyond
Redis BeyondRedis Beyond
Redis Beyond
 
X-Debug in Php Storm
X-Debug in Php StormX-Debug in Php Storm
X-Debug in Php Storm
 
Software Testing
Software TestingSoftware Testing
Software Testing
 
MVC Web Application
MVC Web ApplicationMVC Web Application
MVC Web Application
 
AfNetworking vs. Native + Caching
AfNetworking vs. Native + CachingAfNetworking vs. Native + Caching
AfNetworking vs. Native + Caching
 
Bash
BashBash
Bash
 

Kürzlich hochgeladen

Salient Features of India constitution especially power and functions
Salient Features of India constitution especially power and functionsSalient Features of India constitution especially power and functions
Salient Features of India constitution especially power and functions
KarakKing
 
Vishram Singh - Textbook of Anatomy Upper Limb and Thorax.. Volume 1 (1).pdf
Vishram Singh - Textbook of Anatomy  Upper Limb and Thorax.. Volume 1 (1).pdfVishram Singh - Textbook of Anatomy  Upper Limb and Thorax.. Volume 1 (1).pdf
Vishram Singh - Textbook of Anatomy Upper Limb and Thorax.. Volume 1 (1).pdf
ssuserdda66b
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptx
heathfieldcps1
 
1029 - Danh muc Sach Giao Khoa 10 . pdf
1029 -  Danh muc Sach Giao Khoa 10 . pdf1029 -  Danh muc Sach Giao Khoa 10 . pdf
1029 - Danh muc Sach Giao Khoa 10 . pdf
QucHHunhnh
 

Kürzlich hochgeladen (20)

General Principles of Intellectual Property: Concepts of Intellectual Proper...
General Principles of Intellectual Property: Concepts of Intellectual  Proper...General Principles of Intellectual Property: Concepts of Intellectual  Proper...
General Principles of Intellectual Property: Concepts of Intellectual Proper...
 
How to Create and Manage Wizard in Odoo 17
How to Create and Manage Wizard in Odoo 17How to Create and Manage Wizard in Odoo 17
How to Create and Manage Wizard in Odoo 17
 
Fostering Friendships - Enhancing Social Bonds in the Classroom
Fostering Friendships - Enhancing Social Bonds  in the ClassroomFostering Friendships - Enhancing Social Bonds  in the Classroom
Fostering Friendships - Enhancing Social Bonds in the Classroom
 
Micro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdfMicro-Scholarship, What it is, How can it help me.pdf
Micro-Scholarship, What it is, How can it help me.pdf
 
Kodo Millet PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
Kodo Millet  PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...Kodo Millet  PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
Kodo Millet PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
 
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptxBasic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
 
How to Manage Global Discount in Odoo 17 POS
How to Manage Global Discount in Odoo 17 POSHow to Manage Global Discount in Odoo 17 POS
How to Manage Global Discount in Odoo 17 POS
 
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptxHMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
 
Sociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning ExhibitSociology 101 Demonstration of Learning Exhibit
Sociology 101 Demonstration of Learning Exhibit
 
How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17How to Give a Domain for a Field in Odoo 17
How to Give a Domain for a Field in Odoo 17
 
Salient Features of India constitution especially power and functions
Salient Features of India constitution especially power and functionsSalient Features of India constitution especially power and functions
Salient Features of India constitution especially power and functions
 
Python Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docxPython Notes for mca i year students osmania university.docx
Python Notes for mca i year students osmania university.docx
 
Vishram Singh - Textbook of Anatomy Upper Limb and Thorax.. Volume 1 (1).pdf
Vishram Singh - Textbook of Anatomy  Upper Limb and Thorax.. Volume 1 (1).pdfVishram Singh - Textbook of Anatomy  Upper Limb and Thorax.. Volume 1 (1).pdf
Vishram Singh - Textbook of Anatomy Upper Limb and Thorax.. Volume 1 (1).pdf
 
ICT role in 21st century education and it's challenges.
ICT role in 21st century education and it's challenges.ICT role in 21st century education and it's challenges.
ICT role in 21st century education and it's challenges.
 
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
TỔNG ÔN TẬP THI VÀO LỚP 10 MÔN TIẾNG ANH NĂM HỌC 2023 - 2024 CÓ ĐÁP ÁN (NGỮ Â...
 
Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structure
 
Mehran University Newsletter Vol-X, Issue-I, 2024
Mehran University Newsletter Vol-X, Issue-I, 2024Mehran University Newsletter Vol-X, Issue-I, 2024
Mehran University Newsletter Vol-X, Issue-I, 2024
 
ICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptxICT Role in 21st Century Education & its Challenges.pptx
ICT Role in 21st Century Education & its Challenges.pptx
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptx
 
1029 - Danh muc Sach Giao Khoa 10 . pdf
1029 -  Danh muc Sach Giao Khoa 10 . pdf1029 -  Danh muc Sach Giao Khoa 10 . pdf
1029 - Danh muc Sach Giao Khoa 10 . pdf
 

Php + MySql Optimization

  • 1. PHP  +  MySQL   Optimization  
  • 2. Introduction •  The report includes project-related (EU) queries, tables or databases example. •  We can learn simple php/mysql optimization. •  Know the main idea of using index in a table.
  • 3. Let’s start from simple cases
  • 4. Let’s start from simple cases Avoid excess variables function  isSomething()   {                  $is_something  =  false;                    if  ($some_condition_happens)  {                            $is_something  =  true;                    }                      return  $is_something;   }  
  • 5. Let’s start from simple cases Use cache (eg. APC, memcache)
  • 6. Let’s start from simple cases Avoid queries inside a loop. $player_ids = array(1, 2, 3, 4, 5, 6, 7, 8); foreach ($player_ids as $id) { $players_infos[] = $db->query(“SELECT * FROM player WHERE id = ?”, array($id)); }
  • 7. Let’s start from simple cases Select only needed columns.
  • 8. Let’s start from simple cases count(*) vs count(col_name)
  • 9. Let’s start from simple cases limit 1 when retrieving a unique row.
  • 11. Index to remember Without an index, MySQL must begin with the first row and then read through the entire table to find the relevant rows.
  • 12. Index to remember If there is a choice between multiple indexes, MySQL normally uses the index that finds the smallest number of rows
  • 13. Index to remember To retrieve rows from other tables when performing joins, MySQL can use indexes on columns more efficiently if they are declared as the same type and size. (Comparison of dissimilar columns may prevent use of indexes if values cannot be compared directly without conversion.)
  • 14. Index to remember “Index has significant cost. So you should not create index everywhere.” - http://lab.klab.org/ mysql-bootcamp/key.html
  • 16. Examples Scenario : Imagine you have a table that will store millions of records (eg. item_history) and you don’t have indexes.
  • 17. Examples The table structure : id int(10) unsigned player_id unsigned item_master_id unsigned type enum('INC','DEC') reason int(10) int(10)
  • 18. Examples The problem : When you try to select data from a table without index See how many rows were checked after the search?
  • 19. Examples The solution : We are going to add index for the player_id column ALTER TABLE `item_history` ADD INDEX ( `player_id` ) See the advantage of adding an index? The search took 1 row search only.
  • 20. Examples Upon looking on the table structure which column/s can be used as index when you want to retrieved a player’s item history?
  • 21. Exercise Table Name : unit_history Description : Tracks player’s record when he/she gained, evolved, etc.. a unit. Table structure : id player_id unit_master_id type ‘ITEM’) created int(10) int(10) int(10) enum(‘INC’, ‘DEC’, ‘EVOLVED’, ‘EXP’, timestamp
  • 22. Exercise The Scenario : List player ids who gained and evolved the unit id 10 The Question : What are the possible index we might need in order to retrieve the data faster.
  • 23. Using index in joins •  columns that you will use as the join •  •  condition ( ON a.id = b.id ) should be indexed. LEFT JOIN will use indexed column from left ( a.id ) RIGHT JOIN will use indexed column from right ( b.id )
  • 24. Did you know? That we MySQL has a built-in profiling tool? SET PROFILING = 1; SELECT COUNT(*) FROM table_name WHERE id = 1; SHOW PROFILE FOR QUERY 1; SHOW PROFILES;