2017-02-05 5 views
2

Я получаю результат массива собственного запроса в Doctrine. ЗапросПримечание: неопределенный индекс в результате массива из доктрины родных запросов

$conn = $em->getConnection(); 
    $sql = 'SELECT * FROM Stock_drink d WHERE id=?'; 
    $stmt = $conn->prepare($sql); 
    $stmt->bindValue(1,$idstockdrink); 
    $stmt->execute(); 
    $stockdrink = $stmt->fetchAll(); 

Содержание stockdrink $ является

"{"stockdrink":[{"id":"39","name":"limon","stockamount":"14","price":"2.20","Drink_id":"5","Bar_id":"12"}]}" 

А теперь я хочу, чтобы получить некоторые значения $ stockdrink массив с этими предложениями, но всегда получить неопределенный индекс уведомления. Я смотрел документы, и я не видел решения.

$iddrink = $stockdrink["name"]; 
    $name = $stockdrink["name"]; 
    $price = $stockdrink["price"]; 

Заранее благодарен !!!!

ответ

3

Поскольку метод fetchAll() «извлекает все результаты в массив», так что в вашем конкретном случае, вы должны изменить ваш код таким образом:

$conn = $em->getConnection(); 
$sql = 'SELECT * FROM Stock_drink d WHERE id=?'; 
$stmt = $conn->prepare($sql); 
$stmt->bindValue(1,$idstockdrink); 
$stmt->execute(); 

$stockdrinks = $stmt->fetchAll(); 

$stockdrink = $stockdrinks[0]; 

$iddrink = $stockdrink["name"]; 
$name = $stockdrink["name"]; 
$price = $stockdrink["price"]; 

Подробнее об этом здесь http://docs.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/data-retrieval-and-manipulation.html#fetchall

+0

большое спасибо !!! Оно работает!!!! – DBCooper