Edit report at http://bugs.php.net/bug.php?id=53482&edit=1
ID: 53482
Comment by: iradu at unix-world dot org
Reported by: iradu at unix-world dot org
Summary: Mysqli Object use is much slower than Mysqli
procedural use
Status: Open
Type: Bug
Package: MySQLi related
Operating System: Any
PHP Version: 5.3.3
Block user comment: N
Private report: N
New Comment:
Procedural:
test 1: 0.4619922161
test 2: 0.4763075113
test 3: 0.43635993
Object:
test 1: 0.4942417717
test 2: 0.4999971008
test 3: 0.498214469
Procedural wins 3 of 4 tests, object oriented wins 1 of 4 tests.
Post what you think about all this.
Previous Comments:
------------------------------------------------------------------------
[2010-12-06 11:34:29] iradu at unix-world dot org
Description:
------------
mysqli_query()
is MUCH MUCH FASTER than
mysqli::query()
also MySQL PDO sucks as PDO is for dumb developers.
Test script:
---------------
==== OBJECT STYLE:
<?php
echo 'object:<br>';
for($y=0;$y<10;++$y){
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];$starttime = $mtime;
include 'isett.iphp';
$mysqli=new mysqli($isql['h'],$isql['u'],$isql['p'],$isql['d']);
if(mysqli_connect_errno()) die('Connection Error
'.mysqli_connect_errno().' : '.mysqli_connect_error());
$mysqli->set_charset('utf8');
$mysqli->query("CREATE TABLE IF NOT EXISTS persad_dsa (`id` SMALLINT(3)
UNSIGNED NOT NULL AUTO_INCREMENT,`a_name` VARCHAR(100) CHARACTER SET
utf8 COLLATE utf8_general_ci NOT NULL,`a_desc` VARCHAR(200) CHARACTER
SET utf8 COLLATE utf8_general_ci NOT NULL,PRIMARY
KEY(`id`))ENGINE=MYISAM");
for($i=1;$i<2000;++$i){
$mysqli->query('INSERT INTO persad_dsa (a_name,a_desc)
VALUES(\'=+=+=+=+=+'.($i+1000).'+=+=+=+=+=\',\'------------------------------------------------'.($i+321).'-------\')');
}
$query="SELECT * FROM persad_dsa";
if($result=$mysqli->query($query)){
while($row=$result->fetch_assoc()){
$array[]='|-'.$row['id'].'|'.$row['a_name'].'|'.$row['a_desc'].'-|';
}
$result->close();
}
$mysqli->query("DROP TABLE IF EXISTS persad_dsa");
$mysqli->close();
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];echo $mtime-$starttime.'<br>';
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
}
echo '---<br>procedural:<br>';
for($y=0;$y<10;++$y){
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];$starttime = $mtime;
include 'isett.iphp';
$mysqli=mysqli_connect($isql['h'],$isql['u'],$isql['p'],$isql['d']);
if(mysqli_connect_errno()) die('Connection Error
'.mysqli_connect_errno().' : '.mysqli_connect_error());
mysqli_set_charset($mysqli,'utf8');
mysqli_query($mysqli,"CREATE TABLE IF NOT EXISTS persad_dsa (`id`
SMALLINT(3) UNSIGNED NOT NULL AUTO_INCREMENT,`a_name` VARCHAR(100)
CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,`a_desc`
VARCHAR(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,PRIMARY
KEY(`id`))ENGINE=MYISAM");
for($i=1;$i<2000;++$i){
mysqli_query($mysqli,'INSERT INTO persad_dsa (a_name,a_desc)
VALUES(\'=+=+=+=+=+'.($i+1000).'+=+=+=+=+=\',\'------------------------------------------------'.($i+321).'-------\')');
}
$query="SELECT * FROM persad_dsa";
if($result=mysqli_query($mysqli,$query)){
while($row=mysqli_fetch_assoc($result)){
$array[]='|-'.$row['id'].'|'.$row['a_name'].'|'.$row['a_desc'].'-|';
}
mysqli_free_result($result);
}
mysqli_query($mysqli,"DROP TABLE IF EXISTS persad_dsa");
mysqli_close($mysqli);
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];echo $mtime-$starttime.'<br>';
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
}
?>
//==== PROCEDURAL STYLE
<?php
echo 'procedural:<br>';
for($y=0;$y<10;++$y){
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];$starttime = $mtime;
include 'isett.iphp';
$mysqli=mysqli_connect($isql['h'],$isql['u'],$isql['p'],$isql['d']);
if(mysqli_connect_errno()) die('Connection Error
'.mysqli_connect_errno().' : '.mysqli_connect_error());
mysqli_set_charset($mysqli,'utf8');
mysqli_query($mysqli,"CREATE TABLE IF NOT EXISTS persad_dsa (`id`
SMALLINT(3) UNSIGNED NOT NULL AUTO_INCREMENT,`a_name` VARCHAR(100)
CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,`a_desc`
VARCHAR(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,PRIMARY
KEY(`id`))ENGINE=MYISAM");
for($i=1;$i<2000;++$i){
mysqli_query($mysqli,'INSERT INTO persad_dsa (a_name,a_desc)
VALUES(\'=+=+=+=+=+'.($i+1000).'+=+=+=+=+=\',\'------------------------------------------------'.($i+321).'-------\')');
}
$query="SELECT * FROM persad_dsa";
if($result=mysqli_query($mysqli,$query)){
while($row=mysqli_fetch_assoc($result)){
$array[]='|-'.$row['id'].'|'.$row['a_name'].'|'.$row['a_desc'].'-|';
}
mysqli_free_result($result);
}
mysqli_query($mysqli,"DROP TABLE IF EXISTS persad_dsa");
mysqli_close($mysqli);
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];echo $mtime-$starttime.'<br>';
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
}
echo '---<br>object:<br>';
for($y=0;$y<10;++$y){
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];$starttime = $mtime;
include 'isett.iphp';
$mysqli=new mysqli($isql['h'],$isql['u'],$isql['p'],$isql['d']);
if(mysqli_connect_errno()) die('Connection Error
'.mysqli_connect_errno().' : '.mysqli_connect_error());
$mysqli->set_charset('utf8');
$mysqli->query("CREATE TABLE IF NOT EXISTS persad_dsa (`id` SMALLINT(3)
UNSIGNED NOT NULL AUTO_INCREMENT,`a_name` VARCHAR(100) CHARACTER SET
utf8 COLLATE utf8_general_ci NOT NULL,`a_desc` VARCHAR(200) CHARACTER
SET utf8 COLLATE utf8_general_ci NOT NULL,PRIMARY
KEY(`id`))ENGINE=MYISAM");
for($i=1;$i<2000;++$i){
$mysqli->query('INSERT INTO persad_dsa (a_name,a_desc)
VALUES(\'=+=+=+=+=+'.($i+1000).'+=+=+=+=+=\',\'------------------------------------------------'.($i+321).'-------\')');
}
$query="SELECT * FROM persad_dsa";
if($result=$mysqli->query($query)){
while($row=$result->fetch_assoc()){
$array[]='|-'.$row['id'].'|'.$row['a_name'].'|'.$row['a_desc'].'-|';
}
$result->close();
}
$mysqli->query("DROP TABLE IF EXISTS persad_dsa");
$mysqli->close();
$mtime = explode(' ',microtime());$mtime = (float)$mtime[1] +
(float)$mtime[0];echo $mtime-$starttime.'<br>';
$mtime='';$starttime='';$isql=array();$mysqli='';$i=1;$query='';$array=array();$result='';$row=array();
}
?>
//====
Expected result:
----------------
PHP 5.3 is going in a wrong direction dudes !
Actual result:
--------------
I can't predict
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/bug.php?id=53482&edit=1