lundi 24 février 2020

why Class not found in php pdo

hello i am trying to return an array of int with this function

but php does not recognize my class is puts this error "Fatal error: Class 'obj \ EntitePiece' not found in [my path]\ web \ InfoWeb-TP-CRUD \ L3_TP_InfoWeb_CSS \ php \ class \ MyPDO.php on line 273 "

, the 2 classes are in the same folder

public function getAllValeurPiece() : array{
        $result = array();
        $tab = $this->query("SELECT distinct * FROM piece order by valeur")
            ->fetchAll(PDO::FETCH_CLASS, 'obj\EntitePiece');

        foreach ($tab as $value){
            array_push($result, $value->getValeur());
        }

        print $result[0];

        return $result;
    }

and my class EntitePiece

<?php
namespace obj;

class EntitePiece{

  /**
  * identifiant de la piece
  * @var int
  */
  protected $id_piece;

  /**
  * face de la piece
  * @var int
  */
  protected $face;

  /**
  * valeur faciale de la piece
  * @var float
  */
  protected $valeur;

  /**
  * diametre de la piece
  * @var float
  */
  protected $diametre;

  /**
  * epaisseur de la piece
  * @var float
  */
  protected $epaisseur;

  /**
  * masse de la Piece
  * @var float
  */
  protected $masse;

  /**
  * materiau de la piece
  * @var int
  */
  protected $materiau;

  /**
  * @return $this->id_piece
  */
  public function getId_piece() : int {
    return $this->id_piece;
  }

  /**
  * @param $id_piece
  */
  public function setId_piece($id_piece) : void {
    $this->id_piece=$id_piece;
  }

  /**
  * @return $this->$face
  */
  public function getFace() : int {
    return $this->face;
  }

  /**
  * @param $face
  */
  public function setFace($face) : void {
    $this->face=$face;
  }

  /**
  * @return $this->diametre
  */
  public function getDiametre() : float {
    return $this->diametre;
  }

  /**
  * @param $diametre
  */
  public function setDiametre($diametre) : void {
    $this->diametre=$diametre;
  }

  /**
  * @return $this->epaisseur
  */
  public function getEpaisseur() : float {
    return $this->epaisseur;
  }

  /**
  * @param $epaisseur
  */
  public function setEpaisseur($epaisseur) : void {
    $this->epaisseur=$epaisseur;
  }

  /**
  * @return $this->masse
  */
  public function getMasse() : float {
    return $this->masse;
  }

  /**
  * @param $masse
  */
  public function setMasse($masse) : void {
    $this->masse=$masse;
  }

  /**
  * @return $this->materiau
  */
  public function getMateriau() : int {
    return $this->materiau;
  }

  /**
  * @param $materiau
  */
  public function setMateriau($materiau) : void {
    $this->materiau=$materiau;
  }

    /**
     * @return float
     */
    public function getValeur(): float
    {
        return $this->valeur;
    }

    /**
     * @param float $valeur
     */
    public function setValeur(float $valeur): void
    {
        $this->valeur = $valeur;
    }



  public static function getTestEntitePiece(): EntitePiece
  {
      $test = new EntitePiece();
      $test->setDiametre(1);
      $test->setEpaisseur(1);
      $test->setValeur(1);
      $test->setFace(1);
      $test->setMasse(1);
      $test->setId_piece(1);
      $test->setMateriau(1);
      return $test;
  }
}

the whole pdo class, do not pay attention to certain methods which are being corrected

<?php
namespace obj;


use PDO;
use PDOStatement;

use obj\EntiteFace;
use obj\EntitePays;
use obj\EntitePiece;
use obj\EntiteMateriau;
use obj\EntiteQuantite;

class MyPDO extends PDO
{
    /**
     * gestion statique des accès SGBD
     * @var PDO
     */
    private $_pdo;

    /**
     * @var PDOStatement
     */
    private $_pdos_selectAll;

    /**
     * gestion statique de la requête préparée de selection
     * @var PDOStatement
     */
    private $_pdos_select;

    /**
     * gestion statique de la requête préparée de mise à jour
     * @var PDOStatement
     */
    private $_pdos_update;

    /**
     * gestion statique de la requête préparée d'insersion
     * @var PDOStatement
     */
    private $_pdos_insert;

    /**
     * gestion statique de la requête préparée de supression
     * @var PDOStatement
     */
    private $_pdos_delete;

    /**
     * PreparedStatement associé à un SELECT, calcule le nombre de pièces dans la table
     * @var PDOStatement;
     */
    private $_pdos_count;

    /**
     * @var string
     */
    private $nomTable;

    /**
     * MyPDO constructor.
     * @param $sgbd
     * @param $host
     * @param $db
     * @param $user
     * @param $password
     * @param $nomTable
     */

    public function __construct($sgbd, $host, $db, $user, $password, $nomTable)
    {
        parent::__construct("$sgbd:host=".$host.";dbname=".$db, $user, $password);

        // pour récupérer aussi les exceptions provenant de PDOStatement
        $this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $this->nomTable = $nomTable;

    }


    public function initPDOS_selectAll() {
        $this->_pdos_selectAll = $this->_pdo->prepare('SELECT * FROM'.$this->nomTable);
    }

    /**
     * préparation de la requête SELECT * FROM $this->nomTable WHERE $nomColId = :id
     * instantiation de $this->pdos_select
     * @param string $nomColID
     */
    public function initPDOS_select(string $nomColID = "id"): void
    {
        $requete = "SELECT * FROM ".$this->nomTable ." WHERE $nomColID = :$nomColID";
        $this->_pdos_select = $this->_pdo->prepare($requete);
    }

    /**
     * @param string $nomColId
     * @param array $colNames
     */
    public function initPDOS_update(string $nomColId, array $colNames): void {
        $query = "UPDATE ".$this->nomTable." SET ";
        foreach ($colNames as $colName) {
            $query .= $colName."=:".$colName.", ";
        }
        $query = substr($query,0, strlen($query)-2);
        $query .= " WHERE ".$nomColId."=:".$nomColId;
        $this->_pdos_update =  $this->_pdo->prepare($query);
    }

    /**
     * @param string $id
     * @param array $assoc
     */
    public function update(string $id, array $assoc): void {
        if (! isset($this->_pdos_update))
            $this->initPDOS_update($id, array_keys($assoc));
        foreach ($assoc as $key => $value) {
            $this->getPdosUpdate()->bindValue(":".$key, $value);
        }
        $this->getPdosUpdate()->execute();
    }


    /**
     * @param array
     */
    public function initPDOS_insert(array $colNames): void {
        $query = "INSERT INTO ".$this->nomTable." VALUES(";
        foreach ($colNames as $colName) {
            $query .= ":".$colName.", ";
        }
        $query = substr($query,0, strlen($query)-2);
        $query .= ')';
        $this->_pdos_insert = $this->_pdo->prepare($query);
    }

    /**
     * @param array $assoc
     */
    public function insert(array $assoc): void {
        if (! isset($this->_pdos_insert))
            $this->initPDOS_insert(array_keys($assoc));
        foreach ($assoc as $key => $value) {
            $this->getPdosInsert()->bindValue(":".$key, $value);
        }
        $this->getPdosInsert()->execute();
    }

    /**
     * @param string
     */
    public function initPDOS_delete(string $nomColId = "id"): void {
        $this->_pdos_delete = $this->_pdo->prepare("DELETE FROM ". $this->nomTable
            ." WHERE $nomColId=:".$nomColId);
    }

    /**
     * @param array $assoc
     */
    public function delete(array $assoc) {
        if (! isset($this->_pdos_delete))
            $this->initPDOS_delete(array_keys($assoc)[0]);
        foreach ($assoc as $key => $value) {
            $this->getPdosDelete()->bindValue(":".$key, $value);
        }
        $this->getPdosDelete()->execute();
    }

    public function initPDOS_count() {
        $this->_pdos_count = $this->_pdo->prepare('SELECT COUNT(*) FROM '.$this->nomTable);
    }

    /**
     * @return PDO
     */
    public function getPdo(): PDO
    {
        return $this->_pdo;
    }

    /**
     * @return PDOStatement
     */
    public function getPdosSelect() : PDOStatement
    {
        return $this->_pdos_select;
    }


    /**
     * @return PDOStatement
     */
    public function getPdosSelectAll(): PDOStatement
    {
        return $this->_pdos_selectAll;
    }

    /**
     * @return PDOStatement
     */
    public function getPdosUpdate(): PDOStatement
    {
        return $this->_pdos_update;
    }

    /**
     * @return PDOStatement
     */
    public function getPdosInsert(): PDOStatement
    {
        return $this->_pdos_insert;
    }

    /**
     * @return PDOStatement
     */
    public function getPdosDelete(): PDOStatement
    {
        return $this->_pdos_delete;
    }

    /**
     * @return PDOStatement
     */
    public function getPdosCount(): PDOStatement
    {
        return $this->_pdos_count;
    }

    /**
     * @return string
     */
    public function getNomTable(): string
    {
        return $this->nomTable;
    }

    public function constructPiece($id = 0): EntitePiece {
        $piece = $this->query("SELECT * from piece where id_piece = $id")->fetchObject("obj\EntitePiece");;

        return $piece;
    }

    public  function constructFace($id): EntiteFace {
        $face = $this->query("SELECT * from face where id_face = $id")->fetchObject("obj\EntiteFace");
        return $face;
    }

    public function constructPays($id): EntitePays {
        $pays = $this->query("SELECT * from pays where id_pays = $id")->fetchObject("obj\EntitePays");

        return $pays;
    }

    public function constructMateriau($id): EntiteMateriau {
        $materiau = $this->query("SELECT * from materiau where id_materiau = $id")->fetchObject("obj\EntiteMateriau");

        return $materiau;
    }

    // id est ici l'id de la face et non l'id de
    public function constructQuantite($id): EntiteQuantite {
        $quantite = $this->query("SELECT * from quantite where face = $id")->fetchObject("obj\EntiteQuantite");

        $quantite->setQuantite($quantite);
    }

    public function getAllValeurPiece() : array{
        $result = array();
        $tab = $this->query("SELECT distinct * FROM piece order by valeur")
            ->fetchAll(PDO::FETCH_CLASS, 'obj\EntitePiece');

        foreach ($tab as $value){
            array_push($result, $value->getValeur());
        }

        print $result[0];

        return $result;
    }

    public function getPiecePays(int $idpays): array{
        $query = $this->query("SELECT * from piece where face in ( SELECT id_face from face where pays = $idpays);");
        $result = array();

        foreach ($query as $id){
            $piece = $this->constructPiece($id);
            array_push($result, $piece);
        }

        return $result;
    }

    public function getAllPays() : array{
        $result = $this->query("SELECT distinct * FROM pays order by nom_pays")
            ->fetchAll(PDO::FETCH_CLASS, 'obj\EntitePays');
        return $result;
    }

    public function getAllFace() : array{
        $result = $this->query("SELECT distinct * FROM face order by description")
            ->fetchAll(PDO::FETCH_CLASS, 'obj\EntiteFace');
        return $result;
    }

    public function getAllMateriau() : array{
        $result = $this->query("SELECT distinct * FROM materiau order by description")
            ->fetchAll(PDO::FETCH_CLASS, 'obj\EntiteMateriau');
        return $result;
    }

    public function updatePiece(EntitePiece $piece) : void{
        $this->query("UPDATE piece SET
        face = $piece->getFace(),
        valeur = $piece->getValeur(),
        diametre = $piece->getDiametre(),
        epaisseur = $piece->getEpaisseur(),
        masse = $piece->getMasse(),
        materiau = $piece->getMateriau()
        WHERE id_piece = $piece->getId_piece()");
    }

    public function deletePiece(EntitePiece $piece) : void{
        $this->query("DELETE from piece WHERE id_piece = $piece->getId_piece()");
    }

    public function updateFace(EntiteFace $face) : void{
        $this->query("UPDATE face SET
        commune = $face->getCommune(),
        pays = $face->getPays(),
        description = $face->getDescription_face()
        WHERE id_face = $face->getId_face()");
    }

    public function deleteFace(EntiteFace $face) : void{
        $this->query("DELETE from face WHERE id_face = $face->getId_face()");
    }

    public function updateMateriau(EntiteMateriau $mat) : void{
        $this->query("UPDATE materiau SET
        description = $mat->getDescription_materiau()
        WHERE id_materiau = $mat->getId_materiau()");
    }

    public function deleteMateriau(EntiteMateriau $mat) : void{
        $this->query("DELETE FROM materieau WHERE id_materiau = $mat->getId_materiau()");
    }

    public function updatePays(EntitePays $pays) : void{
        $this->query("UPDATE pays SET
        nom_pays = $pays->getNom_pays()
        WHERE id_pays = $pays->getId_pays()");
    }

    public function deletePays(EntitePays $pays) : void{
        $this->query("DELETE FROM pays WHERE id_pays = $pays->getId_pays()");
    }

    public function updateQuantite(EntiteQuantite $qtt) : void{
        $this->query("UPDATE quantite SET
        quantite = $qtt->getQuantite(),
        date = $qtt->getDate()
        WHERE face = $qtt->getQ_face()");
    }

    public function deleteQuantite(EntiteQuantite $qtt) : void{
        $this->query("DELETE FROM quantite WHERE face = $qtt->getQ_face()");
    }

}



Aucun commentaire:

Enregistrer un commentaire