Получение Нескольких Наборов результатов с хранимой процедурой в php/mysqli

Используйте пакеты для связанной с группой функциональности вместе.

Обычно вершина Вашего дерева пакета является Вашим доменным именем, инвертированным (com.domain.subdomain) для гарантии уникальности, и затем обычно будет пакет для приложения. Тогда подразделите это связанной областью, таким образом, Ваш FileStorageStrategy мог бы войти, скажем, com.domain.subdomain.myapp.storage, и затем мог бы быть определенный implementations/subclasses/whatever в com.domain.subdomain.myapp.storage.file и com.domain.subdomain.myapp.storage.database. Эти имена могут стать довольно длинными, но import сохраняет их всех наверху файлов, и IDE могут помочь управлять этим также.

Исключения обычно входят в тот же пакет как классы, которые бросают их, поэтому если бы Вы имели, скажем, FileStorageException, то он вошел бы в тот же пакет как FileStorageStrategy. Аналогично интерфейс, определяющий константы, был бы в том же пакете.

нет действительно никакого стандарта как такового, просто используйте здравый смысл, и если все это становится слишком грязным, осуществите рефакторинг!

15
задан MacAnthony 6 November 2009 в 04:18
поделиться

2 ответа

Я думаю, что вам здесь чего-то не хватает (следующее не было проверено):

$stmt = mysqli_prepare($db, 'CALL multiples(?, ?)');
mysqli_stmt_bind_param($stmt, 'ii', $param1, $param2);
mysqli_stmt_execute($stmt);
// fetch the first result set
$result1 = mysqli_use_result($db);
// you have to read the result set here 
while ($row = $result1->fetch_assoc()) {
    printf("%d\n", $row['id']);
}
// now we're at the end of our first result set.
mysqli_free_result($result1);

//move to next result set
mysqli_next_result($db);
$result2 = mysqli_use_result($db);
// you have to read the result set here 
while ($row = $result2->fetch_assoc()) {
    printf("%d\n", $row['id']);
}
// now we're at the end of our second result set.
mysqli_free_result($result2);

// close statement
mysqli_stmt_close($stmt);

Используя PDO , ваш код будет выглядеть так:

$stmt = $db->prepare('CALL multiples(:param1, :param2)');
$stmt->execute(array(':param1' => $param1, ':param2' => $param2));
// read first result set
while ($row = $stmt->fetch()) {
    printf("%d\n", $row['id']);
}
$stmt->nextRowset();
// read second result set
while ($row = $stmt->fetch()) {
    printf("%d\n", $row['id']);
}

Но у меня слышал, что PDOStatement :: nextRowset () не реализован с драйвером MySQL PDO , что делает невозможным получение нескольких наборов результатов:

Таким образом, в зависимости от вашей версии PHP, вам придется придерживаться своего mysqli -решение. Кстати: вы намеренно используете процедурный стиль? Использование объектно-ориентированного стиля с mysqli сделает ваш код более привлекательным (мое личное мнение).

14
ответ дан 1 December 2019 в 04:09
поделиться

Похоже, MySQLi может поддерживать только несколько наборов результатов через mysqli_multi_query () ,

1
ответ дан 1 December 2019 в 04:09
поделиться
Другие вопросы по тегам:

Похожие вопросы: