Ir para conteúdo
Carcleo

Erro na listagem com PDO

Recommended Posts

Estou tentando aprender PDO mas estou tendo dificuldades.

Tenho 3 arquivos:

Planos.php

    <?php
      
      namespace PLANOS;
      
      use TABELAS\Tabelas;
      
      require_once "Tabelas.php";
      
      class Planos extends Tabelas {      
          
          public function __construct ($_conexao, $_tabela) {
             
             parent::__construct ($_conexao, $_tabela);
             
         }
          
      }
    
    ?>

Tabelas.php

    <?php
    
     namespace TABELAS;
      
     abstract class Tabelas {
         
         private $conexao;    
         private $tabela; 
         private $ultimoCadastrado;
         
         public function __construct($_conexao, $_tabela) {
             
             $this->conexao = $_conexao;
             
             $this->tabela = $_tabela;
             
         }
         
         public function cadastrar (array $objeto) {
             
             $parametros = $valores = "";
             
             foreach ($objeto as $objeto=>$valor):
             
               $parametros.= $objeto.",";         
               $valores.= "'".$valor."',";
               
             endforeach;     
             
             $parametros = substr($parametros,0, -1);
             $valores = substr($valores,0, -1);
             
             $sql = "INSERT INTO ".$this->tabela." (".$parametros.") VALUES (".$valores.")";
             
             $query = $this->conexao->prepare($sql);
             
             $execucao = $query->execute();
             
             $this->ultimoCadastrado = $this->conexao->lastInsertId();
             
             return $execucao;
             
             
         }
         
         public function ultimoIdCadastrado () {    
              
             return $this->ultimoCadastrado;
             
         }
         
         
         public function editar (array $objeto, $id) {
             
             $str = "";
             
             foreach ($objeto as $objeto=>$valor):
             
               $str .= $objeto ."='". $valor."',";         
               
             endforeach;
             
             $str = substr($str, 0, -1);
             
             $sql = "UPDATE ".$this->tabela." SET ".$str." WHERE id".ucfirst($this->tabela)."=".$id;
             
             $query = $this->conexao->prepare($sql);
             
             return $query->execute();
              
         }
         
         public function bloquear ($id, $bloqueado) {         
         
             $sql = "UPDATE ".$this->tabela." SET bloqueado = '".$bloqueado."' WHERE id".$this->tabela." = ".$id;
             
             $query = $this->conexao->prepare($sql);
             
             return $query->execute();
             
             
         }
    
         public function excluir ($id) {         
         
             $sql = "DELETE FROM ".$this->tabela." WHERE id".$this->tabela." = ".$id;
    
             $query = $this->conexao->prepare($sql);        
             
             return $query->execute(); 
             
         }
         
         public function listar () {
             
             $sql = "SELECT  FROM ".$this->tabela;
             
             $query = $this->conexao->prepare($sql);
             
             $query->execute();
             
             return $query->fetch( PDO::FETCH_ASSOC );
             
         }
         
         public function listarId ($id = null) {
             
             $sql = "SELECT  FROM ".$this->tabela;
             
             if ($id != null) $sql .= " WHERE id".ucfirst($this->tabela)."=".$id;
             
             $query = $this->conexao->prepare($sql);    
                  
             return $query->execute();
             
         }
         
         public function listarParametros ($where) {
             
             $sql = "SELECT  FROM ".$this->tabela." ".$where;
             
             $query = $this->conexao->prepare($sql);
             
             return $query->execute();
             
         }
         
     }
     
    ?>

Index.php

    <?php 
     
      ini_set("display_errors",true);
      ini_set("display_startup_erros",1);
      error_reporting(E_ALL | E_NOTICE | E_STRICT);
      
      use PLANOS\Planos;
      use TABELAS\Tabelas;
    
      $conexao = new PDO('mysql:host=localhost;dbname=funeraria2', 'root', 'mysql');
       
      $objeto = array (
          
          "tipo" => 's',
          "nome" => "Carlos",
          "login" => "caca",
          "senha" => "1234",
          "bloqueado" => "n"
          
      ); 
       
      $objeto2 = array (
          "idAdministradores" => 3,
          "tipo" => 's',
          "nome" => "Castro",
          "login" => "abcd",
          "senha" => "4321",
          "bloqueado" => "s"    
      ); 
    
      require_once "Planos.php";
       
      $planos = new Planos($conexao, "administradores");
      
      echo $planos->cadastrar($objeto) ? 1 : 2;
      echo "<br />";
      echo $planos->ultimoIdCadastrado();
      echo "<br />";
      echo $planos->editar($objeto2, 3) ? 1 : 2;
      echo "<br />";
      echo $planos->bloquear(3, 's') ? 1 : 2;
      echo "<br />";
      echo $planos->excluir(4) ? 1 : 2;
      echo "<br />";
      
    
      print "<pre>";
      print_r($planos->listar());
      print "</pre>";
    
      echo $planos->listar() ? 1 : 2;
      echo "<br />";
      echo $planos->listarId(1) ? 1 : 2;
      echo "<br />";
      echo $planos->listarParametros("WHERE nome = 'Carlos'") ? 1 : 2;
      echo "<br />";
    
    ?>

Quando rodo esse script recebo o erro abaixo:

    Fatal error:  Uncaught Error: Class 'TABELAS\PDO' not found in D:\Trabalhos\host\htdocs\crud\Tabelas.php:102
    Stack trace:
    #0 D:\Trabalhos\host\htdocs\crud\index.php(47): TABELAS\Tabelas->listar()
    #1 {main}
      thrown in D:\Trabalhos\host\htdocs\crud\Tabelas.php on line 102

Mas não consigo achar que erro é esse!

 

Engraçado é que só não está fazendo leitura. Mas gravação, exclusão, edição, normal!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Em teoria, com o autoload bem construído, não precisaria do require.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por Eduardo S. B. de Oliveira
      Senhores, preciso de uma ajuda, estou criando um formulário onde o checkbox fique "checked" quando clicar em cima, mas o detalhe e que quando atualizar a pagina o checkbox permaneça marcado. É possível? 
    • Por gersonab
      Tenho este sql que funciona normal:
      <?php $idtor = (int)$_GET['id_tor']; $dia = $_GET['dia']; $sql3 = "SELECT * FROM cantos INNER JOIN campeonato ON id_camp = id_campeonato INNER JOIN torneio ON id_tor = id_torneio WHERE data = :dia AND id_torneio = :idtor ORDER BY cantosfim DESC, pontos DESC, cantos DESC"; $stmt = $pdo->prepare($sql3); $stmt->bindParam(':idtor', $idtor); $stmt->bindParam(':dia', $dia); $stmt->execute(); while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { ?> porém este outro não retorna nada, nem erro...
      <?php $idtor = (int)$_GET['id_tor']; $consul = "SELECT id_cantos, id_torneio, id_campeonato, SUM(cantosfim) AS cantfin, SUM(pontos) AS pontfin FROM cantos INNER JOIN campeonato ON id_camp = id_campeonato INNER JOIN torneio ON id_tor = id_torneio WHERE id_tor = :idtor ORDER BY pontfin DESC, cantfin DESC"; $stmt = $pdo->prepare($consul); $stmt->bindValue(':idtor', $idtor); $stmt->execute(); while ($lin = $stmt->fetch(PDO::FETCH_ASSOC)) { ?> não consigo encontrar o erro.
    • Por Carcleo
      Estou tentando rotacionar um texto no PDF com mPDF mas não estou conseguindo.
      $css = ' <style> ul { } ul li { float: left; list-style: none; /*necessáro width no campo */ } ul li span.vertical { display: block; //transform: rotate(270deg); /*necessáro display: block*/ text-rotate : 270; } </style>'; $html = ' <ul> <li style="width: 150px"><span class="vertical">Elefante</span></li> <li style="width: 150px"><span>Não</span></li> <li style="width: 150px"><span>Come</span></li> <li style="width: 150px"><span class="vertical">Bananada</span></li> </ul>'; require_once "../vendor/autoload.php"; $pdf = new \Mpdf\Mpdf(['debug' => true]); $pdf->AddPage(); $pdf->charset_in = "UTF-8"; $pdf->SetFont('Arial','B',16); $pdf->WriteHTML( $css, 1 ); $pdf->WriteHTML( $html ); $pdf->Output(); Obs.: O restante do estilo funciona normal.
       
      O problema é apenas no PDF. No navegador, os spans giram normalmente.
    • Por jpaulorh
      O código grifado de amarelo está sem os caracteres de comentário, e quando é executado fica como se estivesse comentado e não executa o php.
       

       
      Segue abaixo o código para alguém me explicar esse mistério... 
       
      <!DOCTYPE html>
      <html>
      <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no, minimal-ui">
        <meta name="apple-mobile-web-app-capable" content="yes">
        <meta name="apple-mobile-web-app-status-bar-style" content="black">
        <title>CNSC</title>
          <!-- Favicons-->
        <link rel="icon" href="img/cnsc.png" sizes="32x32">
        <!-- Favicons-->
        <link rel="apple-touch-icon-precomposed" href="img/cnsc.png">
        <!-- Path to Framework7 Library CSS-->
        <link rel="stylesheet" href="css/framework7.ios.min.css">
        <link rel="stylesheet" href="css/framework7.ios.colors.min.css">
        <!-- Path to your custom app styles-->
        <link rel="stylesheet" href="css/my-app.css">
        <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet" integrity="sha384-wvfXpqpZZVQGK6TAh5PVlGOfQNHSoD2xbE+QkPxCAFlNEevoEH3Sl0sibVcOQVnN" crossorigin="anonymous">
        <link rel="stylesheet" href="carbon/css/carbon-components.css">
        <!--Import Google Icon Font-->
        <link href="http://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
        <script
        src="https://code.jquery.com/jquery-3.1.1.min.js"
        integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8="
        crossorigin="anonymous"></script>
        <!-- Path to Framework7 Library JS-->
        <script type="text/javascript" src="js/framework7.min.js"></script>
        <script type="text/javascript" src="js/app.min.js"></script>
        <script src="carbon/js/carbon-components.js"></script>
        <script type="text/javascript">
        // Iniatilize do aplicativo com suas propriedades
        $(document).ready(function() {
          myApp = new Framework7({
            material: true,
            materialPageLoadDelay: 3,
            materialPreloaderHtml: '<span class="preloader-inner"><span class="preloader-inner-gap"></span><span class="preloader-inner-left"><span class="preloader-inner-half-circle"></span></span><span class="preloader-inner-right"><span class="preloader-inner-half-circle"></span></span></span>',
            modalTitle: 'CNSC',
            modalButtonCancel: 'Cancelar',
            modalPreloaderTitle: 'Carregando...',
          });
          verificaLogado();
        });
        </script>
      </head>
      <body class="theme-black">
        <!-- Status bar overlay for fullscreen mode-->
        <div class="statusbar-overlay"></div>
        <!-- Panels overlay-->
        <div class="panel-overlay"></div>
        <!-- Left panel with reveal effect-->
        <div class="panel panel-left panel-reveal">
          <div class="content-block">
            <div class="list-block">
              <ul>
                <li>
                  <a href="javascript: localStorage.clear(); location.href = 'index.html'" class="list-button item-link external"><i class="fa fa-sign-out color-icon" aria-hidden="true"></i> Sair</a>
                </li>
              </ul>
            </div>
          </div>
        </div>
        <!-- Views-->
        <div class="views">
          <!-- Your main view, should have "view-main" class-->
          <div class="view view-main">
            <!-- Top Navbar-->
            <div class="navbar">
              <div class="navbar-inner">
                <!-- We have home navbar without left link     icon-bars -->
                <div class="left"><a href="#" class="link icon-only open-panel"> <i class="icon"></i><img class="img img-responsive" style="position:absolute; margin-top: 0px; margin-left: 10px" src="img/cnsc.png"></a></div> 
                <br>
                <div class="center" style="position:absolute; font-weight:bold; color: #0080FF; margin-top: 0px; margin-left: 25%">Clínica N. Sra. do Carmo</div>
                            <?php include('slideshow.php');?>
              </div>
            </div>
            <!-- Pages, because we need fixed-through navbar and toolbar, it has additional appropriate classes-->
            <div class="pages navbar-through toolbar-through">
              <!-- Page, data-page contains page name-->
              <div data-page="index" class="page">
                <!-- Scrollable page content-->
      <div class="page-content">
                  <br>
                  <div class="login-screen-title">Atendimentos</div>
                  <!-- 
        Copyright IBM Corp. 2016, 2018
        This source code is licensed under the Apache-2.0 license found in the
        LICENSE file in the root directory of this source tree.
      -->
      <ul data-accordion class="bx--accordion">
          <li data-accordion-item class="bx--accordion__item">
            <button class="bx--accordion__heading" aria-expanded="false" aria-controls="pane1">
                <a href="li_listas.html" class="color-blue external" style="font-size: 18px;">
              <div class="bx--accordion__title"><i class="fa fa-list" aria-hidden="true"></i> Listas Atendimentos</a></div>
            </button>
          </li>
          <li data-accordion-item class="bx--accordion__item">
            <button class="bx--accordion__heading" aria-expanded="false" aria-controls="pane2">
            <a href="cad_usuarios.html" class="color-blue external" style="font-size: 18px;">
              <div class="bx--accordion__title"><i class="fa fa-user-circle-o" aria-hidden="true"></i> Usuários</a></div>
            </button>
          </li>
          <li data-accordion-item class="bx--accordion__item">
            <button class="bx--accordion__heading" aria-expanded="false" aria-controls="pane3">
            <a href="rel_relatorios.html" class="color-blue external" style="font-size: 18px;">
              <div class="bx--accordion__title"><i class="fa fa-bar-chart" aria-hidden="true"></i> Relatórios</a></div>
            </button>
          </li>
      </ul>
                </div>
              </div>
            </div>
          </div>
        </div>
      </body>
      </html>
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.