PDOStatement :: rowCount
PDOStatement :: rowCount - Retorna a instrução SQL que está em um número de linhas afetadas (PHP 5> = 5.1.0, PECL pdo> = 0.1.0)
explicação
gramática
int PDOStatement::rowCount ( void )
PDOStatement :: rowCount () retorna um DELETE, INSERT ou UPDATE afetou o número de linhas executadas pelo objeto PDOStatement correspondente.
Se a instrução SQL executada por um PDOStatement associada foi uma instrução SELECT, alguns dados podem retornar o número de linhas devolvidas por esta declaração. No entanto, este método não pode garantir que todos os dados são válidos, e para aplicações portáteis não deve contar com este método.
Valor de retorno
Retorna o número de linhas.
Exemplos
Retorna o número de linhas excluídas
PDOStatement :: rowCount () retorna o número de linhas afetadas por DELETE, INSERT, UPDATE, ou declaração de impacto.
<?php /* 从 FRUIT 数据表中删除所有行 */ $del = $dbh->prepare('DELETE FROM fruit'); $del->execute(); /* 返回被删除的行数 */ print("Return number of rows that were deleted:\n"); $count = $del->rowCount(); print("Deleted $count rows.\n"); ?>
Saída do exemplo acima:
Return number of rows that were deleted: Deleted 9 rows.
Calculado pelo número de linhas devolvidas por uma instrução SELECT
Para a maioria dos bancos de dados, PDOStatement :: rowCount () não retorna o número de linhas afetadas por uma instrução SELECT. Um método alternativo é usar PDO :: query () e destina-se a emitir uma instrução SELECT na mesma condição expressão SELECT COUNT (*) declaração, e depois usar PDOStatement :: fetchColumn () para obter o número de linhas retornadas. Assim que o aplicativo pode executar corretamente.
<?php $sql = "SELECT COUNT(*) FROM fruit WHERE calories > 100"; if ($res = $conn->query($sql)) { /* 检查符合 SELECT 语句的行数 */ if ($res->fetchColumn() > 0) { /* 发出一条真正的 SELECT 语句并操作返回的结果 */ $sql = "SELECT name FROM fruit WHERE calories > 100"; foreach ($conn->query($sql) as $row) { print "Name: " . $row['NAME'] . "\n"; } } /* 没有匹配的行 -- 执行其他 */ else { print "No rows matched the query."; } } $res = null; $conn = null; ?>
O exemplo acima saída é:
apple banana orange pear