ID:               41325
 User updated by:  php-qa at sebastianmendel dot de
 Reported By:      php-qa at sebastianmendel dot de
 Status:           Open
 Bug Type:         Documentation problem
 Operating System: Windows / Linux
 PHP Version:      5.2.2
 New Comment:

just to clarify: my test works as expected and not as i have written,
SORRY!


Previous Comments:
------------------------------------------------------------------------

[2007-05-08 17:17:46] php-qa at sebastianmendel dot de

ok, my fault, it is not a really a bug in mysqli_affected_rows() - it
is more a documentation bug

the mysql c api function mysql_affected_rows returns not only for teh
last INSERT, UPDATE, REPLACE or DELETE, but for SELECT too

"returns the number of rows changed (for) UPDATE), deleted (for DELETE,
or inserted (for INSERT. For SELECT  statements, mysql_affected_rows()
works like mysql_num_rows()."

http://dev.mysql.com/doc/refman/5.1/en/mysql-affected-rows.html

and mysqli_affected_rows() does it the same way, of course, but the php
manual does read other

"Returns the number of rows affected by the last INSERT, UPDATE,
REPLACE or DELETE query."

http://php.net/mysqli_affected_rows

------------------------------------------------------------------------

[2007-05-08 15:28:06] [EMAIL PROTECTED]

Cannot reproduce on Linux with both client & server of version 5.0.26.

------------------------------------------------------------------------

[2007-05-08 15:07:07] [EMAIL PROTECTED]

I can't reproduce this with 5.0.27. I get the expected output of 1.

Do you have any other sort of special configuration or setting?

------------------------------------------------------------------------

[2007-05-08 14:50:46] php-qa at sebastianmendel dot de

Description:
------------
issuing an insert statement that raises warnings mysqli_affected_rows()
returns the warning count instead of inserted rows count

tested with MySQL server 5.0, 5.1 and 5.2 (6.0)

Reproduce code:
---------------
// open db connection/select db
//$mysqli = mysqli_...
// create table
$sql = 'CREATE TABLE `test` (
  `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  `int` int(11) NOT NULL,
  `int2` int(11) NOT NULL,
  PRIMARY KEY (`id`)
)';
mysqli_query($mysqli, $sql);
// insert row
$sql = 'INSERT INTO `test` (`int`, `int2`) VALUES ('', '');'
mysqli_query($mysqli, $sql);

echo mysqli_affected_rows($mysqli);

Expected result:
----------------
1

Actual result:
--------------
2


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=41325&edit=1

Reply via email to