Jump to content
Sapinn

PDO como estender a conexao para outros arquivos

Recommended Posts

Iai galera beleza? Estou com um erro simples aqui como eu faço para estender minha conexão para outros arquivos ? Estou tentado fazer mas está dado um erro aqui

 

arquivo connection.php

 

<?php

class Conexao{

    public $db_name = 'pessoa';

    public $host = 'localhost';

    public $user = 'root';

    public $pass = '';

 

    public function __construct()

    {

        try {

            $pdo = new PDO("mysql:db_name=".$this->db_name.";host=".$this->host,$this->user,$this->pass);                                         

        } catch (PDOException $e) {

            echo "Erro no banco ".$e->getMessage();

            exit();

        }

    }

     

}

 

arquivo Pessoa.php

 

<?php

include 'connection.php';

class Pessoa {

    private $pdo;

 

    public function __construct()

    {   

        $this->pdo = new Conexao();

    }

 

    public function buscarDados(){

        $stmt = [];

        $sql = $this->pdo->query("SELECT * FROM pessoa

        order by id desc");

        $stmt = $sql->fetchAll(PDO::FETCH_ASSOC);

        return $stmt;

    }

}

 

arquivo index.php

 

<?php
    require_once 'models/Pessoa.php';
    $p = new Pessoa();
?>
<!DOCTYPE html>
<html lang="pt-br">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="assets/css/style.css">
    <title>Crud PDO </title>
</head>
<body>
    <section id="esquerda">
        <form action="">
            <h2>Cadastrar Pessoa</h2>
            <label for="nome">Nome: </label>
            <input type="text" name="nome" id="nome">
            <label for="telefone">Telefone: </label>
            <input type="text" name="telefone" id="telefone">
            <label for="email">Email:</label>
            <input type="text" name="email" id="email">
            <input type="submit" value="Cadastrar">
        </form>
    </section>

    <section id="direita">
    <?php
        $p->buscarDados();
    ?>
        <table>
            <tr id="titulo">
                <td>Nome</td>
                <td>Telefone</td>
                <td colspan="2">Email</td> 
            </tr>
            <tr>
                <td>Maria</td>
                <td>00000000</td>
                <td>maria@gmail.com</td>
                <td><a href="">Editar</a> <a href="">Excluir</a></td>
            </tr>
        </table>
    </section>
</body>
</html>

 

Erro que é apresentado:

Fatal error: Uncaught Error: Call to undefined method Conexao::query()

Share this post


Link to post
Share on other sites

Estou retornando agora mas o erro continua 

<?php



class Conexao{



    public $db_name = 'pessoa';



    public $host = 'localhost';



    public $user = 'root';



    public $pass = '';







    public function __construct()



    {



        try {



            $pdo = new PDO("mysql:db_name=".$this->db_name.";host=".$this->host,$this->user,$this->pass);                                         

            return $pdo;



        } catch (PDOException $e) {



            echo "Erro no banco ".$e->getMessage();



            exit();



        }



    }



     



}

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Sapinn
      Galera estou usando o PHPStorm para alguns projetos e estou com meus arquivos marcados em vermelho não sei oq é alguem pode me ajuda?
       
       

    • By danielambrosio
      Estou trabalhando numa programação PHP é conectado na tabela (cl_configs) para reconhece coluna name que reconhece esses 5 campos.
      e também que adiciona esses 5 valores é adicionado nessa outra tabela (cl_ads_block_ips) nesses 8 coluna (id, ip, clicks, last_click, dads_refresh_qtd, dads_refresh_data, dads_refresh_ldata, clicks_rotativo_dia).
      E a conexão que eu usa era de outro site e não estou tendo problema e configurar em outro site que reconhece essa banco de dados abaixo.
       
      <?php $host = "localhost"; $user = "ads"; $pass = "_CMpFF4Hpa!G_gTh"; $dbname = "ads"; $port = 3306; try {     $conn = new PDO('mysql:host=' . $host . ';port=' . $port . ';dbname=' . $dbname, $user, $pass);     //echo "Conexão com banco de dados realizado com sucesso!"; } catch (PDOException $err) {     echo "Erro: Conexão com banco de dados não foi realizada com sucesso. Erro gerado " . $err->getMessage(); } ?>  
      Conecta com sucesso só não está reconhecendo a tabela (cl_configs) e nem adicionando na tabela (cl_ads_block_ips).
       
       
      Agora não sei porque não esta reconhecendo (cl_configs) e nem adicionando (cl_ads_block_ips).
       
       


    • By ment0r
      Boa tarde a todos.

      Estou iniciando um estudo com o banco MySQL (trabalho co PostgreSQL e Firebird) para futuros trabalhos. Bom, me deparei com um problema chato: caracteres especiais.
      Um exemplo: T�tulo.
      Não consigo exibir no meu site tais caracteres. O banco tem Charset/Collation: utf8/utf8_bin como configuração.
      Já usei o utf_encode e utf_decode - não resolveu.

      Alguém sabe o que mais posso fazer?
      Desde já, muito obrigado.
    • By asacap1000
      Galera salve salve!!
      Estou com um projeto em que são armazenados vídeos, porém seguindo os requisitos exigidos, para visualizar e baixar esses vídeos eles tem que aparecer com numero de cadastro do usuário que está acessando no centro do video como uma marca d'agua.
       
      Para simplesmente aparecer na tela eu consigo fazer uma camada superior com css e apresentar os dados do usuário mas para baixar o vídeo ele já faz sem a marca.
       
      Vocês conhecem algum recurso pra adicionar essa marca? ela não pode ficar no arquivo original pois outros usuário poderão baixar com sua identificação na tela.
       
      Se alguem puder me dar um norte ajudaria muito
    • By marcelo.ourico
      Estou precisando fazer o envio de um XML via webservice. Estou utilizando PHP 7.4 e nuSoap.

      Porém esse XML de envio possui várias tags com hífen. Por exemplo <tag-name></tag-name>.
       
      Esse hífen tem sido um problema, principalmente por que eu não posso enviar o XML como string. Apenas como objeto. Então imaginem isso:
       
      $objeto = simplexml_load_string($string_xml);  
      Se simplesmente eu tentar resgatar o valor da TAG já dá erro...
       
      $campo1= $objeto->tag-name;
      O erro ocorre em função de que o hífen é um caractere reservado do PHP... Então como resolver?

      Independente disso, quando eu tento fazer o envio via nuSoap, também recebo erro abaixo:
      wsdl->getTypeDef('tag-name', 'http://xyz.abr...')
      wsdl->serializeType('tag-name', 'tag-name', Object(SimpleXMLElement), '

      Alguém já passou por isso? Sabe como resolver? Pode dar uma dica?
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.