Ir para conteúdo
junior almeida

Problema com select

Recommended Posts

Tenho o seguinte problema quando faço um select ele me retorna somente os últimos 3 dados do banco de dados

 

listarArquivos

  public function listarArquivo(){
        try{
            $id_usuario = $this->id;
            
            $query = new DbFunctions();
            $query->selectFiles("SELECT * FROM arquivos WHERE idUsuario = '$id_usuario'");

            //var_dump($id_usuario);
            foreach($query->getResult() as $chave => $dado){
                echo "<tr>
				<td>".$dado->id_arquivo."</td>
				<td>".$dado->nome."</td>
				<td>".$dado->tamanho."</td>
				<td>".$dado->data."</td>
				<td>
					<a href='visualizar_arquivo.php?acao=visualizar&id_arquivo=".$dado->id_arquivo."'target='_blank'><i class='fa fa-external-link fa-2x' aria-hidden='true'></i></a>
					<a href='visualizar_arquivo.php?acao=download&id_arquivo=".$dado->id_arquivo."'target='_blank'><i class='fa fa-cloud-download fa-2x' aria-hidden='true'></i></a>
                    <a href='?link1=".$dado->id_arquivo."' name='link1' ><i class='fa fa-trash fa-2x' aria-hidden='true'></i></a>
                </td>";
            }
            //$query->getResult();
            echo "<pre>";
            var_dump($query->getResult());
            echo "</pre>";

        }catch(PDOException $e){
            echo $e->getMessage();
        }
    }

 

 

selectFiles

public function selectFiles($sql){
        $query = $this->conecta()->query($sql);
        foreach($query as $row){
            $this->setResult($query->fetchAll(\PDO::FETCH_OBJ));
            //$this->setResult($row);
            return true;
        }
    }

 

no meu banco de dados tem 4 registros com o id do usuário quando faço o select ele me mostra apenas os últimos 3 dados que esta no banco, inclusive no meu objeto getResult() também me mostra 3 objetos sendo que deveria ter 4, se alguém puder me dar uma ajuda agradeço

Compartilhar este post


Link para o post
Compartilhar em outros sites

me mostra o banco de dados pode???? os dados estão sendo enviados para o seu banco de dados???? todos!!?

Compartilhar este post


Link para o post
Compartilhar em outros sites

minha tabela arquivos

-- phpMyAdmin SQL Dump
-- version 4.5.1
-- http://www.phpmyadmin.net
--
-- Host: 127.0.0.1
-- Generation Time: 04-Jun-2018 às 22:07
-- Versão do servidor: 10.1.13-MariaDB
-- PHP Version: 7.0.6

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8mb4 */;

--
-- Database: `documentos`
--

-- --------------------------------------------------------

--
-- Estrutura da tabela `arquivos`
--

CREATE TABLE `arquivos` (
  `id_arquivo` int(11) NOT NULL,
  `idUsuario` int(11) DEFAULT NULL,
  `nome` varchar(255) NOT NULL,
  `tamanho` varchar(255) NOT NULL,
  `conteudo` varchar(255) NOT NULL,
  `pasta` varchar(255) NOT NULL,
  `data` date NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

--
-- Extraindo dados da tabela `arquivos`
--

INSERT INTO `arquivos` (`id_arquivo`, `idUsuario`, `nome`, `tamanho`, `conteudo`, `pasta`, `data`) VALUES
(1, 8, 'arquivo de teste 1', '25151', 'conteudo 1', 'teste1', '2018-06-20'),
(2, 8, 'arquivo de teste 2', '125581', 'conteudo 2', 'teste 2', '2018-06-14'),
(3, 8, 'arquivo teste 3', '3265651', 'conteudo 3', 'teste 3', '2018-06-14'),
(4, 8, 'arquivo teste 4', '64846', 'conteudo 4', 'teste 4', '2018-06-14');

--
-- Indexes for dumped tables
--

--
-- Indexes for table `arquivos`
--
ALTER TABLE `arquivos`
  ADD PRIMARY KEY (`id_arquivo`),
  ADD UNIQUE KEY `nome` (`nome`);

--
-- AUTO_INCREMENT for dumped tables
--

--
-- AUTO_INCREMENT for table `arquivos`
--
ALTER TABLE `arquivos`
  MODIFY `id_arquivo` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

 

não estou entendendo o problema que ele esta me dando ele consulta o banco normalmente mas dos 4 registros que estão la ele só me traz os  3 últimos, fiz um teste e modifiquei o id do usuário do primeiro registro colocando como id 9 e no banco ficou apenas 3 registros com o id 8 que é o id do usuário logado e meu objeto me retorno os 2 últimos registros pelo que entendi ele não ta pegando o primeiro registro mesmo estando tudo correto

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 03/06/2018 at 18:26, junior almeida disse:

$this->setResult($query->fetchAll(\PDO::FETCH_OBJ));

 

troque por isso

<?php $this->setResult($query->fetch(\PDO::FETCH_OBJ)); ?>

Compartilhar este post


Link para o post
Compartilhar em outros sites

isso não vai funcionar pois o fetch só vai me trazer um dado do mysql eu quero trazer todos os dados que estão relacionados com o usuário que esta logado, vou tentar explicar melhor o meu problema.

 

tenho uma tabela arquivos nessa tabela contem o id do arquivo e o id do usuário que este arquivo pertence, exemplo o usuário de id 8 esta logado e no sistema vai listar todos os arquivos que tem o idUsuario = 8 que são 4 arquivos relacionado ao usuário de id 8 so que meu método de listar arquivos sempre omiti um arquivo exemplo são 4 arquivos registrados com o idUsuario = 8 ele não me lista 4 arquivos ele esta me listando 3 ou seja um arquivo ele não me mostra, se eu adicionar mais um arquivo pro usuário de id 8 ficando com 5 arquivos relacionado ao idUsuario = 8 ele vai me listar 4 em vez de listar os 5.

 

não estou conseguindo entender o que esta acontecendo se é a minha logica de selecionar os arquivos ou se é a maneira que estou colocando esses dados em um objeto. O objeto tem limite de tamanho de armazenamento? 

 

não sei se ficou confuso pois também não estou entendendo esse problema.

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 RSN
      Boa Noite, 
      Gostaria de saber se existe a possibilidade de gravar além do id do option value outra variavel, para enviar via post.
      <div class="form-group"> <label class="col-md-4 control-label" for="txtgrupo">Tipo de Pagamento : </label> <div class="col-md-4"> <select id="" class="selectpicker" data-live-search="true" name="tipo_pagamento" > <?php $query = mysql_query("SELECT * FROM tipo_pagamento ORDER BY id ASC"); while($result = mysql_fetch_array($query)) { echo '<option value="'.$result["id"].'">'.$result["nome_tipo"].'</option>'; } ?> </select> </div> </div>  
    • Por JeanTDZ
      Eu tenho um form com algumas informações etc. O form envia pro banco de dados e tudo mais, funcional.
       
      Alguém teria algum exemplo que após o submit, o form é transformado em pdf/doc e direcionado para uma pasta/ftp já criada.?
    • Por jparenque
      Pessoal, estou precisando de um código em php que faça o seguinte:

      1- acesse uma url capture e grave o código fonte
      2- acesse novamente a mesma url, capture o código fonte e compare com o código da primeira captura
      3- se o código for igual ao da primeira captura ele acessa novamente e compara novamente
      4- se o código for diferente do da primeira captura ele tem que abrir o navegador Chrome e ir para essa url através do navegador.
      5- o fim do código deverá ser apenas quando ele acessar a url encontrar um conteúdo diferente do da primeira captura.

      Vou rodar o php na máquina local. O objetivo é monitorar uma página url específica com relação à uma alteração que ocorrerá. E quando ocorrer precisarei atuar nessa página imediatamente.

      Obrigado a todos!
    • Por reisleandro
      Alguém ai conhece um servidor php portável que possa rodar direto de um pendrive e que não apresente a mensagem de bloqueio do firewall (Imagem abaxio). O servidor embutido do php faz exatamente isso mas apenas como sigle thread. Queria uma solução um pouco mais robusta que pudesse rodar em qualquer maquina sem apresentar essa mensagem. Plataforma alvo Windows.
       

    • Por JOSELUISALD
      Bom dia. Em minha aplicação o cliente quer uma cópia de seu sistema localmente e remoto (hospedado). Tem como eu fazer a sincronização dos bancos de dados, para que tudo que seja feito localmente seja inserido automaticamente no banco remoto? Desde já obrigado.
×

Informação importante

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