Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Kelen Miranda Silva

Conexao PDO

Recommended Posts

Olá, preciso de uma ajuda. Sou iniciante em php.

Tinha uma conexão desta forma:

$conexao = new PDO('mysql:host=localhost;dbname=meubanco','meuuser','');

No entanto para fins de aprendizado ela ficou assim...

try
	{    
    	class dbconn 
			{
				public $dblocal;
              	public function __construct()
                  {
                  }
    
		public function initDBO()
          	{
				$this->dblocal = new PDO("mysql:host=localhost;dbname=meubanco;charset=latin1","root","",array(PDO::ATTR_PERSISTENT => true));
              	$this->dblocal->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
          	}
			}
    
    
	}
?>

Beleza. A conexão funciona sem problemas. 

Agora veja esta linha:

$result = $conexão->prepare($select); 

Aqui eu usava a variável ($conexão), agora tentei usar a variável ($this) e recebo um erro. (Fatal error: Using $this when not in object context in )

Como resolver isto, já que o nome não é mais "$conexão" e sim "$this" que não pode ser usado? Grato.

Compartilhar este post


Link para o post
Compartilhar em outros sites

$this é uma pseudo variável (quer dizer que ela se comporta como uma variável, mas, você não na verdade uma variável).

 

Citar

The pseudo-variable $this is available when a method is called from within an object context. $this is a reference to the calling object (usually the object to which the method belongs, but possibly another object, if the method is called statically from the context of a secondary object).

 

A parte grifada explica que $this está disponível dentro de um método que é chamado de dentro do contexto de um objeto, ou seja, uma referência do objeto chamado.

 

Você utiliza a variável $this dentro da class dbconn, pois, você está dentro de um contexto do objeto.

 

Para continuar utilizando o método PDO::prepare, você pode realizar de duas formas

 

Acessando a variável que contém a instância de PDO:

$result = $conexao->dblocal->prepare($select);

Ou criando o método prepare na class dbconn e realizando a chamada na PDO:

class dbconn
{
    /** demais código omitido **/

    public function prepare(string $statement , array $drive_options = array()) : PDOStatement
    {
        $this->dblocal->prepare($statement , $drive_option);
    }
}

Essas poderiam ser alternativas para a resolução da questão.

 

Entretanto, a PDO é uma biblioteca bem completa. Contanto que você não esteja criando nenhum comportamento novo e/ou adicionando novas funcionalidades, não há motivos para encapsular a PDO em outra classe. Utilize-a diretamente como ela é.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Tentei todas as opções...

Nesta,

$result = $conexao->dblocal->prepare($select);

Gera o seguinte erro:

Notice: Undefined variable: dblocal in C:\xampp\htdocs\admacuco4\index.php on line 57

Notice: Trying to get property of non-object in C:\xampp\htdocs\admacuco4\index.php on line 57

Fatal error: Call to a member function prepare() on null in C:\xampp\htdocs\admacuco4\index.php on line 57

Agora veja meu código:

dbconn.php

<?php

class dbconn {
	public $dblocal;
	public function __construct()
	{

	}
	public function initDBO()
	{
		$this->dblocal = new PDO("mysql:host=localhost;dbname=meubanco;charset=latin1","meuuser","minhasenha",array(PDO::ATTR_PERSISTENT => true));
		$this->dblocal->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
		
	}
?>

Agora minha página com erro:

Obs. Arquivo anterior incluso com require...

 

...

<?php
	if(isset($_POST['logar'])){
		//Recuperar Dados do Form
		$usuario=trim(strip_tags($_POST['usuario'])); 
		$senha=trim(strip_tags($_POST['senha']));
		
		//Selecionar Banco de Dados$
		$select = "SELECT * from tab_usuarios WHERE email=:usuario AND senha=:senha";
		
	try	{
		$result = $conexao->dblocal->prepare($select); //Limha 57 com erro
		$result->bindParam(':usuario',$usuario, PDO::PARAM_STR);
		$result->bindParam(':senha',$senha, PDO::PARAM_STR);
		$result->execute();
		
		//O código continua, mas acho que até dá pra ver meu problema.
		//A ideia aqui é a criação de um menu, que recupera dados do banco Mysql.	
?>


...

Esta variável $conexão, não existe em lugar algum. Portanto o PHP informa isto... Ela existia antes de eu mexer no código, como informei no início do post.

 

Lembrando que tenho pouco tempo de estudo do PHP. Estou vindo para ele cheio de manias de Acces/VBA. Lendo demais aqui... mas com a ajuda de vcs, penso que vai dar certo.

Compartilhar este post


Link para o post
Compartilhar em outros sites
17 horas atrás, Kelen Miranda Silva disse:

Esta variável $conexão, não existe em lugar algum. Portanto o PHP informa isto... Ela existia antes de eu mexer no código, como informei no início do post.

 

Lembrando que tenho pouco tempo de estudo do PHP. Estou vindo para ele cheio de manias de Acces/VBA. Lendo demais aqui... mas com a ajuda de vcs, penso que vai dar certo.

 

Acho que você não entendeu o conceito ou se atropelou na orientação a objeto.

Em fim é muito conteúdo para explicar aqui, então sugiro que pesquise a respeito de php orientado a objeto. Pelo fato de que não fez a instância da classe e ainda quer pegar um objeto, inseri-lo dentro de uma variável que não existe executando um método da classe que também não existe passando um parâmetro que não possui valor algum.

$result = $conexao->dblocal->prepare($select);  // Nunca isso vai funcionar

 

Como disse tente aprender alguma coisa sobre php orientado a objeto. E veja isso onde mostrei minhas algumas de minhas classes PDO:

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
2 horas atrás, Omar~ disse:

Acho que você não entendeu o conceito ou se atropelou na orientação a objeto.

Você tem razão...

2 horas atrás, Omar~ disse:

Como disse tente aprender alguma coisa sobre php orientado a objeto. E veja isso onde mostrei minhas algumas de minhas classes PDO:

É exatamente isso que estou fazendo. Estou lendo vários manuais e vendo videos e agora procurei o fórum. Enfim, é muito conteúdo.

Só queria entender  como fazer pra que eu possa substituir a conexão de

$conexao = new PDO('mysql:host=localhost;dbname=meubanco','meuuser','');

para o jeito que está, dentro de uma classe.

 

2 horas atrás, Omar~ disse:

$result = $conexao->dblocal->prepare($select);  // Nunca isso vai funcionar

Isto funcionava antes com a conexão do jeito acima. E também  tentei como a Gabriel sugeriu.

 

Como o amigo Gabriel ensinou, $this, não pode ser usado neste caso. Entendi. 

 

Mudei o tipo de conexão. 

E aqui o que deveria mudar?

20 horas atrás, Kelen Miranda Silva disse:

try { $result = $conexao->dblocal->prepare($select); //Limha 57 com erro

 

Tentei isto...

$conexão= new dbconn();

antes da linha acima, mas também não deu...

 

De qualquer forma, grata desde já...

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Kelen Miranda Silva o seu erro é exatamente tentar utilizar um objeto que não foi instanciado.

 

O erro abaixo é o que mais explica o problema.

Citar

Notice: Trying to get property of non-object in C:\xampp\htdocs\admacuco4\index.php on line 57

Traduzindo: Tentando obter a propriedade de um "não objeto".

 

Como eu não vi o seu código completo, eu bato na tecla que já foi mencionada. O objeto $conexao não foi instanciado.

try
{
    $conexao = new dbconn();
    $result = $conexao->dblocal->prepare($select);
}
catch (Exception $exception)
{
}

Esse código acima deve funcionar sem problemas. Se não funcionar, existe algum erro em outro lugar.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ao seguir sua dica, ele me retornou o erro:


Fatal error: Call to undefined method dbconn::prepare() in C:\xampp\htdocs\...\index.php on line 49

 

Segue o código completo:

dbconn.php

<?php

class dbconn {
	public $dblocal;
	public function __construct()
	{

	}
	public function initDBO()
	{
		$this->dblocal = new PDO("mysql:host=localhost;dbname=meubanco;charset=latin1","meuuser","minhasenha",array(PDO::ATTR_PERSISTENT => true));
		$this->dblocal->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
		
	}
	
}
?>

No arquivo com erros:

index.php

<?php
include ("model/dbconn.php");

if(isset($_POST['logar']))
    
{

    //Recuperar Dados do Form
    $usuario=trim(strip_tags($_POST['usuario'])); 
    $senha=trim(strip_tags($_POST['senha']));

    //Selecionar Banco de Dados$
    $select = "SELECT * from tab_usuarios WHERE email=:usuario AND senha=:senha";
    
    try    
        {
            $conexao = new dbconn(); //Incluida por orientacao do Amigo Gabriel - Gerou o erro (atal error: Call to undefined method dbconn::prepare() in C:\xampp\htdocs\...)
            $result = $conexao->prepare($select); //Antes estava aqui o erro.
            $result->bindParam(':usuario',$usuario, PDO::PARAM_STR);
            $result->bindParam(':senha',$senha, PDO::PARAM_STR);
            $result->execute();

            //Contagem de Registro PDO
            $contar = $result->rowCount(); 
            if($contar>0)
                { //Se tiver um registro no BD...
                    $usuario=$_POST['usuario'];
                    $senha=$_POST['senha'];
                
                    //Criamos uma session para guardar o user e a senha
                    $_SESSION['usuarioad'] = $usuario; 
                    $_SESSION['senhaad'] = $usuario; 
                    echo '<div class="alert alert-sucess" role="alert">
                    <strong>Logado com sucesso!</strong> Redirecionando....
                    </div>';
                    header ("Refresh: 2, home.php");exit;

                }else
                    {
                        echo '<div class="alert alert-dangers" role="alert">
                            <strong>Erro ao Logar!</strong> Usuário e/ou Senha Incorretos.
                            </div>';
                    }

        }catch(PDOException $e)
        {

        }
}            

?>

Mais uma vez obrigado pela atenção

Compartilhar este post


Link para o post
Compartilhar em outros sites

Agora você está cometendo o mesmo erro que foi comentado aqui. Você não pode chamar na classe dbconn um método da classe PDO.

 

Que é exatamente o que você está fazendo aqui:

$result = $conexao->prepare($select); //Antes estava aqui o erro.

E as soluções continuam a mesma.

 

Utilize a variável dblocal:

$result = $conexao->dblocal->prepare($select);

Ou crie o método prepare na class dbconn:

class dbconn
{
    /** demais código omitido **/

    public function prepare(string $statement , array $drive_options = array()) : PDOStatement
    {
        $this->dblocal->prepare($statement , $drive_option);
    }
}

Ou utilize diretamente PDO:

$conexao = new PDO("mysql:host=localhost;dbname=meubanco;charset=latin1","meuuser","minhasenha",array(PDO::ATTR_PERSISTENT => true));
$conexao->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
$result = $conexao->prepare($select);

Utillize apenas uma dessas três soluções.

 

A mais recomendada é a última, pois, sua classe dbconn não está criando/alterando nenhum comportamento da classe PDO, logo, a PDO pode ser usada por si só.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Vamos ver....

É tudo pura questão de saber como criar uma classe, acessar seus métodos, e criar objetos dessa classe.

Tentaremos uma coisa então, vamos fazer uma classe simples aqui o nome do arquivo vai ser (MinhaClasseConn.php):

 

Spoiler

<?php
class MinhaClasseConn {

    private $host = 'localhost';
    private $database = 'meu_database';
    private $login = 'root';
    private $senha = '';

    /* Somente esse atributo realmente é necessário */
    private $conexao;

    private function conectarPrivado() {
        /* Primeiro pegamos alguns atributos para colocarmos os dados (Não que isso seja realmente necessário)
         * Então lançamos uma exceção (É para isso que servem blocos TRY)
         */
        try {
            $this->conexao = new PDO("mysql:host={$this->host}; dbname={$this->database}", $this->login, $this->senha);
        } catch (PDOException $erro) {
            echo "A conexão não foi completada por esse motivo:<p><b>{$erro->getMessage()}</b></p>";
        }
        $this->conexao->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        /* Beleza então com isso vamos retornar o atributo com tudo que está armazenado nele */
        return $this->conexao;
    }

    public function acessarConexao() {
        return $this->conectarPrivado();
    }

}

 

 

Opa! Temos uma classe. E ela possui 2 métodos, um para executar a conexão e outro método público para podemos chamar essa conexão. LEGAL

 

Podemos então testar se deu certo. Criamos um novo arquivo.php e fazemos isso:

Spoiler

<?php
require ('MinhaClasseConn.php');

$objeto = new MinhaClasseConn();

// Isso é apenas para testar se conseguimos conectar
var_dump($objeto->acessarConexao());

 

Se tudo ocorreu bem nosso objeto recebeu 2 dados da classe PDO. Deve aparecer algo tipo assim: object(PDO)#2 (0) { }

 

Então vimos como criar a classe como criar um objeto e como acessar um método da classe.

 

Que tal agora tentar selecionar algum dado no banco de dados? Vamos tentar....

No mesmo arquivo criamos uma variável e armazenamos nosso objeto que tem o método que faz parte dele

$variavel = $objeto->acessarConexao();

Mas nada acontece com isso. Apesar que nesse momento armazenamos a toda a classe e sua conexão em uma variável ou seja, executamos todo aquele código em um única linha. (POO é uma maravilha mesmo)

Tentamos então fazer um select

Spoiler

<?php
require ('MinhaClasseConn.php');

$objeto = new MinhaClasseConn();
try {
    $variavel = $objeto->acessarConexao();
    $tabela = 'usuarios';
    $coluna = 'nome';
    $dados = 'Coelinho da páscoa';

    $query = $variavel->prepare("SELECT * FROM {$tabela} WHERE {$coluna} = :statement");
    $query->bindParam(':statement', $dados, PDO::PARAM_STR);
    $query->execute();
    $arrayDeResultado = $query->fetchAll(PDO::FETCH_ASSOC);

    // E bingo!! Aqui nosso resultado
    echo "<pre>";
    var_dump($arrayDeResultado);
    echo "</pre>";

} catch (PDOException $erro) {
    echo "Ops!? algo errado! Por causa disso: " . $erro->getMessage();
}

 

 

Lógico, isso aqui foi um básico do básico do jeito mais simples, simplificando.... :smile:

Compartilhar este post


Link para o post
Compartilhar em outros sites

Aleluias.... Gabriel e Omar.... Muuuuiiiito obrigada mesmo. Deu certo aqui. Qual das soluções? Todas elas... Fiz vários testes aqui para aprender.Tenho muita dificuldades. Embora todos dizem que POO é mais facil e facilita, acredito, mas mudar do procedural está realmente complicado. O bom que eu estou aprendendo. As ultimas explicações de vocês deixou tudo mais claro. É assim que iniciante como eu entende, porque as vezes algo que é comum pra que já está na area há mais tempo, pode ser um bicho de 7 cabeças pra gente.Valeu mesmo.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Fala galera, tudo certo?
       
      Seguinte: No servidor A estou tentando fazer uma consulta com o servidor B, mas está dando erro.
      Estou usando o mesmo código de conexão do servidor B que funciona perfeitamente, mas no servidor A, dá erro.
      Segue código:
       
      $host = 'servidor B';
      $user = 'user';
      $pass = '********';
      $db   = 'banco';
       
      // conexão e seleção do banco de dados
      $conexao = mysqlI_connect($host, $user, $pass, $db);
      mysqlI_set_charset($conexao,"utf8");
      //print "Conexão rodando e OK!"; 
      //mysqlI_close($conexao);
       
      Alguém pode me ajudar?
    • Por douglas79
      Bom dia,

      Há alguns dias que venho instalar o apache, o php, mysql e o phpmyadmin manualmente e sem obter sucesso. Até consegui rodar o php, porém, quando vou baixar a úitima versão do MYSQL, não tem todos os pacotes nele instalados, inclusive no completo, só encontro o Router.
      Alguém pode me dizer o porquê que isso está ocorrendo?
      Desde já agradeço a ajuda de vocês, que será bem vinda!
      No aguardo!

      Uso a versão 8.3.9 do PHP
      Meu SO é o Windows 10 32 bits
    • Por landerbadi
      Tenho uma tabela chamada "item" com os seguintes campos: id, name, active. Nela tem cadastrado vários itens. No campo "active" eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo active. E outra tabela chamada "product" com os seguintes campos (id, name) com os seguintes registros: 1, Produto A 2, Produto B 3, Produto C E uma terceira tabela chamada "product_item" com os seguintes campos (productID, itemID). No campo productID eu coloco o id de um produto da tabela "product" e no campo "itemID" eu coloco o id do produto da tabela "item". Exemplo: 1, 1 1, 3 1, 4 2, 3 2, 4 Sendo assim o produto A da tabela 'product" comtem os itens casa, cama e moto. Eu preciso fazer uma busca da seguinte maneira:  Eu escolho um registro da tabela "item", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "product" que contenham a palavra "casa" e que os demais itens estejam ativos no siste. Ou seja, que contenham um "S" no campo "active"  Eu consegui fazer isso da seguinte maneira: SELECT P.id, P.name, GROUP_CONCAT(I.name ORDER BY I.name) AS items FROM product P JOIN product_item PI ON P.id = PI.productID JOIN item I ON I.id = PI.itemID AND I.active = 'S' WHERE P.id NOT IN ( SELECT PI.productID FROM product_item PI JOIN item I ON I.id = PI.itemID WHERE I.active IS NULL ) AND P.id IN ( SELECT PI.productID FROM product_item PI JOIN item I ON I.id = PI.itemID WHERE I.name = 'mesa' ) GROUP BY P.id, P.name; O problema que eu estou tendo é o seguinte:
      Quando eu jogo este código para o banco de dados onde eu já tenho os registros cadastrado o php fica lendo uma eternidade e não lista os produtos.
       
      Usando código no banco de dados que eu fiz para testes ele funciona perfeitamente pois nele tem poucos registros.
       
      No banco de dados principal a tabela "item" tem 11.196 registros. A tabela "product" tem 88.214 registros e a tabela "product_item" tem 518.378 registros. 
       
      Eu acredito que, devido o banco de dados ser muito grande, ele não consegue listar.
       
      Alguém sabe de algum meio de resolver isso?
       
       
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, ativo. Nela tem cadastrado vários itens. No campo ativo eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "produtos" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, mesa, moto 2, mesa, casa, cama 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela produtos da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "mesa". Preciso fazer com que o php me liste todos os registros da tabela "produtos" que contenham a palavra "mesa". Até aqui tudo bem eu consigo listar. Estou fazendo assim: <?php $item = "mesa" $sql = mysqli_query($conn, "SELECT * FROM produtos WHERE item1 LIKE '$item' OR item2 LIKE '$item' OR item3 LIKE '$item' LIMIT 10"); while($aux = mysqli_fetch_assoc($sql)) { $id = $aux["id"]; $item1 = $aux["item1"]; $item2 = $aux["item2"]; $item3 = $aux["item3"]; echo $id . " - " . $item1 . ", " . $item2 . ", " $item3 . "<br>"; } ?> O problema é que está listando todos os registros que contém o item mesa. Eu preciso que o php verifique os demais item e me liste somente os registro em que todos os registros estejam ativos no sistema. No exemplo acima ele não deveria listar o registro 3. pois nesse registro contém o item "radio" e este item não está ativo no sistema. Ou seja, o registro "radio" na tabela itens não possui um "S" na coluna "ativo". Alguém sabe como resolver isso?
×

Informação importante

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