1

我已经阅读了有关准备好的语句的所有内容,但我仍然不确定执行顺序......(许多使用不同的顺序)。

这是一个好顺序吗?

$sql = 'SELECT * FROM ... WHERE ... = ?';

$conn = ...connection to database...
$stmt = $conn->stmt_init();
$stmt->prepare($sql);
$stmt->bind_param('i', $param);
$stmt->execute();
$stmt->store_result(); // results are cached and accessed from memeory, therefore faster but use more memory
$num_rows = $stmt->num_rows; // how many? (can only be use with store_result() )
$stmt->bind_result($column, ...);
$stmt->fetch(); // use in loop if necessary
$stmt->free_result(); // use only with store_result()
$stmt->close(); // close prepared statement
$conn->close(); // close database
4

1 回答 1

0

显然不是。

顺序虽然没问题,但是你用过的很多运算符都是多余的,没用的。此外,在执行单个查询的上下文中不应有与连接相关的代码。

include 'db.php'; // here goes connect
$sql = 'SELECT * FROM ... WHERE ... = ?';
$stmt->prepare($sql);
$stmt->bind_param('i', $param);
$stmt->execute();
$stmt->bind_result($column, ...);
$stmt->fetch();

足够的。请注意,如果您有数据,则永远不需要 row_count。

于 2014-04-13T17:56:02.063 回答