Вызов дБ в функции - PullRequest
       30

Вызов дБ в функции

0 голосов
/ 05 июля 2018

Я пытаюсь использовать функцию, которую я написал в моем файле rout.php:

функция такова:

function userScore($uid) {

    $db = $app->get('db');

    //calcolo punteggio totale 
    $query_punti = $db->table('prodotti_sounding')
    ->where('id_utente', $uid)
    ->select('punti')
    ->get();

    $totale_punti = 0;
    foreach($query_punti as $item) {
       $totale_punti += $item->punti;
    }
}

возвращает эту ошибку:

Ошибка тонкого приложения Не удалось запустить приложение из-за следующая ошибка:

Тип: Сообщение об ошибке: вызов функции-члена get () со значением NULL

где я не прав?

EDIT

мой соответствующий код в routes.php после первого ответа:

use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Message\ResponseInterface;
use Illuminate\Database\Connection;
use Slim\Http\UploadedFile;
use Illuminate\Support\Facades\DB as DB;

$container = $app->getContainer();

$app->post('/sendbarcode', function ($request, $response){
            /* parametri barcode */
            /** @var Container $this */
            /** @var Connection $db */

            $barcode = $request->getParsedBodyParam('barcode');
            $id_utente = $request->getParsedBodyParam('id_utente');

            $db = $this->get('db');

            // prepare data for json
            $array['itacheck'] = 0;

            if(checkbarcode($barcode) == 1 ) {
                $array['it_check'] = 1;
                $array['punti'] = 25;
                $array['totalepunti'] = userScore($id_utente);
            }

            $array['barcode'] = $rows;

            if(count($rows) > 0){
                return $response->withJson($array, 200, JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES|JSON_UNESCAPED_LINE_TERMINATORS);
            } 
        });

function userScore($uid) {

    //calcolo punteggio totale in base alle segnalazioni pregresse
    $query_punti = DB::table('prodotti_sounding')
    ->where('id_utente', $uid)
    ->select('punti')
    ->get();

    // check total points
    $totale_punti = 0;
    foreach($query_punti as $item) {
       $totale_punti += $item->punti;
    }
}

1 Ответ

0 голосов
/ 05 июля 2018

Ошибка становится $db = $app->get('db');, потому что вы не определили $app переменную. Instaed из вас может использовать это

//calcolo punteggio totale 
$query_punti = DB::table('prodotti_sounding')
    ->where('id_utente', $uid)
    ->select('punti')
    ->get();

DB полное имя класса \Illuminate\Support\Facades\DB
Редактировать
В этом случае добавьте атрибут $app в аргумент функции

function userScore($uid, $app) {    
    $db = $app->get('db');
...