mysql affected rows

/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
$a = mysql_query("UPDATE `test` SET `value` = 'p' WHERE `id` < '100'");
$b = mysql_query("INSERT INTO `test` (`value`) VALUES ('1')");

Как узнать кол-во измененных рядов, если mysql_affected_rows($a); приводит к Warning: mysql_affected_rows(): supplied argument is not a valid MySQL-Link resource?

1 ответов


У вас же в ошибке написано: в аргументах указан неверный идентификатор соединения. Должно быть так:

mysql_affected_rows($db);
если
$db = mysql_connect('localhost', 'mysql_user', 'mysql_password');
или пустой
mysql_affected_rows(); если нужно вернуть кол-во строк затронутое последним действием. В вашем случае его нужно вызывать 2 раза. Смотрите здесь подробности: http://ru2.php.net/manual/ru/function.mysql-affected-rows.php

Читаем http://ru2.php.net/manual/ru/function.mysql-affected-rows.php :

Возвращаемые значения


Возвращает количество измененных записей в случае успеха, и -1 в случае если последний запрос не удался.

Если последний запрос был DELETE без указания WHERE и, соответственно, таблица была очищена, функция вернёт ноль во всех версиях MySQL до 4.1.2.

При использовании UPDATE, MySQL не обновит колонки, уже содержащие новое значение. Вследствие этого, функция mysql_affected_rows() не всегда возвращает количество рядов, подошедших под условия, только количество рядов, обновлённых запросом.

Запрос REPLACE сначала удаляет запись с указанным первичным ключом, а потом вставляет новую. Данная функция возвращает количество удаленных записей вместе с количеством вставленных.

В случае использования запросов типа "INSERT ... ON DUPLICATE KEY UPDATE", возвращаемое значение будет равно 1 в случае, если была произведена вставка, или 2 при обновлении существующего ряда.
-----------------------------------------------------------
В вашем случае нужно сделать как-то так:
$a = mysql_query("UPDATE `test` SET `value` = 'p' WHERE `id` < '100'");
...
//отправка запроса
mysql_affected_rows();
$b = mysql_query("INSERT INTO `test` (`value`) VALUES ('1')");
mysql_affected_rows();
По логике должно возвращать разные значения. Сохраняйте в переменные. Проверяйте.