Ir para conteúdo
Julio Cavallari

Problema ao selecionar valor minimo numa tabela

Recommended Posts

Estou tentando executar uma query para retornar pra mim qual o valor minimo de uma coluna:

SELECT MIN(nfatura) as nfatura_min FROM `financeiro` WHERE pedido = "857087" AND situacao = 'N';

O problema é que ela me retorna como menor valor 10

Spoiler

image.png.ebf03739acee371a98da987b29e46099.png

 

Só que esse não é o menor valor. Como podem ver no select abaixo, o menor valor pra essa coluna é 2 segundo as cláusulas que coloquei:

Spoiler

image.png.9b54174fccd5b368ba15e43a1f3ce8a4.png

Onde está o erro?

Compartilhar este post


Link para o post
Compartilhar em outros sites

erro nenhum, caso a coluna seja tipo string.

tente mudar p/ 1 tipo numerico, como int por exemplo

Compartilhar este post


Link para o post
Compartilhar em outros sites
11 minutos atrás, Fernando C disse:

erro nenhum, caso a coluna seja tipo string.

tente mudar p/ 1 tipo numerico, como int por exemplo

 

11 minutos atrás, Fernando C disse:

erro nenhum, caso a coluna seja tipo string.

tente mudar p/ 1 tipo numerico, como int por exemplo

SELECT nfatura FROM `financeiro` WHERE pedido = "857087" AND situacao = 'N' ORDER BY nfatura ASC LIMIT 1;

Compartilhar este post


Link para o post
Compartilhar em outros sites
8 horas atrás, Fernando C disse:

erro nenhum, caso a coluna seja tipo string.

tente mudar p/ 1 tipo numerico, como int por exemplo

Era esse mesmo o problema, estava como varchar o campo

Compartilhar este post


Link para o post
Compartilhar em outros sites

Uma outra alternativa é somar com 0 (zero) o valor da coluna, assim o MySql faz o CAST automatico para INT. 

Assim não precisaria alterar o tipo do campo, que as vezes pode gerar impacto em outra parte do sistema.

Teste no Fiddle:

LInk Fiddle

CREATE TABLE Persons (
    PersonID varchar(255)
);

INSERT INTO Persons (PersonID) VALUES ('1'),('2222'),('3'),('4'),('5');

SELECT MAX(PersonID + 0) FROM Persons

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 10/08/2018 at 16:48, Uerlen Santos disse:

Uma outra alternativa é somar com 0 (zero) o valor da coluna, assim o MySql faz o CAST automatico para INT. 

Assim não precisaria alterar o tipo do campo, que as vezes pode gerar impacto em outra parte do sistema.

Teste no Fiddle:

LInk Fiddle


CREATE TABLE Persons (
    PersonID varchar(255)
);

INSERT INTO Persons (PersonID) VALUES ('1'),('2222'),('3'),('4'),('5');

SELECT MAX(PersonID + 0) FROM Persons

 

Muito obrigado pelo dica, bom saber disso, pode ser útil, mas nesse caso alterar o tipo do campo era a melhor solução mesmo, não utilizo em mais lugar nenhum os dados desse campo, somente nessa tabela mesmo. E como ela só pode receber número inteiros via verificação no script PHP não teria porque deixar o campo como varchar

Compartilhar este post


Link para o post
Compartilhar em outros sites

Trabalhe com o tipo correto , evita complicações desnecessárias.

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 Victor Cometti
      Boa noite,
       
      Em algumas de minhas queries de insert eu atualizo quando encontro registro duplicado.
      insert into .... ON DUPLICATE KEY UPDATE ...... Só que descobrir que além de verificar a PRIMARY KEY ele verifica também campos UNIQUE (um ou outro).
      O interessante para mim seria que fizesse update só quando achasse a PRIMARY KEY duplicada e não o campo UNIQUE.
      É possível sem procedure? 
       
    • Por dungol
      Ola Pessoal,
      Comprei um script em php e Mysql e estou precisando de uma ajuda.
      É um script POS simples de vendas. Quando eu faço uma venda o recibo sai apenas o nome do cliente, o telefone e as informaçoes da compra, mas eu gostaria de adicionar neste recibo o endereço do cliente. Na tabela de compra já tem o campo endereço, mas eu não sei como fazer o script adicionar o endereço do cliente nessa  tabela. 
      Obrigada pela ajuda,
      Cristina
    • Por UPeralta
      Olá, preciso de ajuda. A minha função de fetch_object está acessando apenas a primeira linha do resultado da SELECT, mas a seleção está retornando duas linhas. Não sei o que eu estou fazendo errado.
      Class que está fazendo a consulta no banco de dados:
      <?php class permissao_grupo { //Variáveis referentes a colunas public $peg_codigo; public $peg_nome; //Variáveis padrão das classes public $con; public $sql; public $result; //Funções padrão para todas as classes public function __construct() { $this->con = new Conexao(); } public function fetch_object() { $this->result = $this->result->fetch_object(); foreach ($this->result AS $chave => $valor) { $this->$chave = $valor; } } public function num_rows() { return $this->result->num_rows; } //Funções da classe public function montaGrupoMenu() { $sql = "SELECT peg_codigo, peg_nome FROM permissao_grupo "; $this->result = $this->con->Executar($sql); return $this->result; } }  
      Class conexão
      <?php class Conexao { public $host = "localhost"; public $usuario = "root"; public $senha = ""; public $banco = "smart"; public $mysqli; public function __construct() { $this->Abrir(); } public function Abrir() { $this->mysqli = new mysqli(); $this->mysqli->connect($this->host, $this->usuario, $this->senha, $this->banco); } public function Fechar() { $mysqli->close(); } public function Executar($sql){ return $this->mysqli->query($sql); } public function fetch_object(){ print_r($this->mysqli->fetch_assoc()); } }  
      Alguém poderia me ajudar? Já tentei usar o fetch_assoc e o fetch_array para ver se funcionaria, mas também não deu certo.
    • Por Lucasw
      E aí pessoal, estou com um problema que me afrontou essa madrugada toda.
      Estou tentando duplicar valores de dentro de outro valor, porém na hora
      de duplicar eu não tenho conhecimento para um comando que crie novos IDS
      então, está dando erro a horas e eu em busca da solução.
      Podem me ajudar?
       
      INSERT INTO items_rooms (id, room_id, user_id)
      SELECT id, 15602, user_id
      FROM items_rooms WHERE room_id = '15601';
       
      (é onde está negrito que está o problema.)
       
      Bom dia a todos!
       
      CREATE TABLE `items_rooms` (
          `id` VARCHAR(23) NOT NULL,
          `user_id` INT(10) NOT NULL,
    • Por Marcones Borges
      Bom dia, esto tentando inserir dados de um formulário em duas tabelas ao mesmo tempo.
       
      Gostaria de sua ajuda!
       
      Arquivo Insere
       

      $conexao = conexao::getInstance();         // Recebe os dados enviados pela submissão         $acao  = (isset($_POST['acao'])) ? $_POST['acao'] : '';         $id    = (isset($_POST['id'])) ? $_POST['id'] : '';         $nome  = (isset($_POST['nome'])) ? $_POST['nome'] : '';         $funcao = (isset($_POST['funcao'])) ? $_POST['funcao'] : '';         $cpf   = (isset($_POST['cpf'])) ? str_replace(array('.','-'), '', $_POST['cpf']): '';         $status           = (isset($_POST['status'])) ? $_POST['status'] : '';   $sql = 'INSERT INTO historico (registro_ministro, descricao, data_registro, usuario )                VALUES(:registro_ministro, :descricao, :data_registro, :usuario )';                  $stm = $conexao->prepare($sql);             $stm->bindValue(':registro_ministro', $registro_ministro);             $stm->bindValue(':descricao', $descricao);             $stm->bindValue(':data_registro', $data_registro);             $stm->bindValue(':usuario', $usuario);             $retorno = $stm->execute();                          if ($retorno):                 echo "<div class='alert alert-success' role='alert'>Registro editado com sucesso, aguarde você está sendo redirecionado ...</div> ";             else:                 echo "<div class='alert alert-danger' role='alert'>Erro ao editar registro!</div> ";             endif;             echo "<meta http-equiv=refresh content='0;URL=ministros.php'>";         endif; $sql = 'INSERT INTO ministro (nome, cpf,  funcao, status )                VALUES(:nome, :cpf, :rg,  :funcao, :status, )';                                $stm = $conexao->prepare($sql);             $stm->bindValue(':nome', $nome);             $stm->bindValue(':cpf', $cpf);             $stm->bindValue(':status', $status);             $stm->bindValue(':funcao', $funcao);
       
      Porém só executa o ultimo código não executa o primeiro o que pode ser ?
       
×

Informação importante

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