П О Р Т А Л                            
С Е Т Е В Ы Х                          
П Р О Е К Т О В                        
  
Поиск по сайту:
                                                 
Главная

О проекте

Web-мастеру
     HTML & JavaScript
     SSI
     Perl
     PHP
     XML & XSLT
     Unix Shell

MySQL

Безопасность

Хостинг

Другое








Самое читаемое:

Учебник PHP - "Для Чайника".
Просмотров 6070 раз(а).

Иллюстрированный самоучитель по созданию сайтов.
Просмотров 8212 раз(а).

Учебник HTML.
Просмотров 4861 раз(а).

Руководство по PHP5.
Просмотров 1912 раз(а).

Хостинг через призму DNS.
Просмотров 6919 раз(а).

Подборка текстов стандартных документов.
Просмотров 57505 раз(а).

Учебник PHP - Самоучитель
Просмотров 5141 раз(а).

Документация на MySQL (учебник & справочное руководство)
Просмотров 11270 раз(а).

Внешние атаки...
Просмотров 7153 раз(а).

Учебник PHP.
Просмотров 4221 раз(а).

SSI в примерах.
Просмотров 1176 раз(а).



 
 
| Добавить в избранное | Сделать стартовой | Помощь





Учебник РНР
Назад Вперёд

mysql_affected_rows

(PHP 3, PHP 4)

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

Описание

int mysql_affected_rows ([resource link_identifier])

mysql_affected_rows() возвращает количество рядов, задействованных в последнем запросе INSERT, UPDATE или DELETE, ассоциированном с идентификатором link_identifier. Если link identifier не специфицирован, принимается последняя ссылка, открытая функцией mysql_connect().

Примечание: если вы используете транзакции, необходимо вызывать mysql_affected_rows() после запроса INSERT, UPDATE или DELETE, а не после подтверждения транзакции.

Если последним запросом был DELETE без оператора WHERE, все записи таблицы будут удалены, но функция возвратит нуль.

Примечание: при использовании UPDATE, MySQL не обновит столбцы, где новое значение - такое же, как и старое. Это создаёт возможность того, что mysql_affected_rows() совпадёт не с количеством рядов, задействованных реально, а только с рядами, непосредственно изменёнными запросом.

mysql_affected_rows() не работает с операторами SELECT; только с операторами, модифицирующими запись. Для запрашивания количества рядов, возвращённых SELECT, используйте mysql_num_rows().

Если последний запрос потерпел неудачу, эта функция возвратит -1.
Пример 1. Delete-Query
<?php
    /* соединение с БД */
    mysql_pconnect("localhost", "mysql_user", "mysql_password") or
        die ("Could not connect");

    /* это должно возвратить корректное количество удалённых записей */
    mysql_query("DELETE FROM mytable WHERE id < 10");
    printf ("Records deleted: %d\n", mysql_affected_rows());

    /* без оператора where в операторе delete должно возвратить 0 */
    mysql_query("DELETE FROM mytable");
    printf ("Records deleted: %d\n", mysql_affected_rows());
?>

На выходе будет:
Records deleted: 10
Records deleted: 0

Пример 2. Update-Query
<?php
    /* соединение с БД */
    mysql_pconnect("localhost", "mysql_user", "mysql_password") or
        die ("Could not connect");

    /* обновить/Update записи */
    mysql_query("UPDATE mytable SET used=1 WHERE id < 10");
    printf ("Updated records: %d\n", mysql_affected_rows());
mysql_query("COMMIT");
?>

На выходе:
Updated Records: 10

См. также mysql_num_rows(), mysql_info().


Назад Оглавление Вперёд
Функции MySQL Вверхmysql_change_user


Если Вы не нашли что искали, то рекомендую воспользоваться поиском по сайту: