Jump to content
Fórum Script Brasil
  • 0

Array: Como excluir chave que contém valor = ""?


Bruno Aguiar

Question

Fala galera, boa tarde. Estou com o seguinte problema: tenho 5 tipos de filtros numa página. Posso usar 1 ou até os 5 ao mesmo tempo. Daí, pra consultar no banco de dados, eu fiz da seguinte maneira:

($data_inicial_filtro <> "" AND $data_final_filtro <> "") ? $filtro_data = "data_ped>='$data_inicial_filtro' AND data_ped<='$data_final_filtro'" : $filtro_data = "";
                    
($valor_final_filtro <> "") ? $filtro_valor = "valor_ped>='$valor_inicial_filtro' AND valor_ped<='$valor_final_filtro'" : $filtro_valor = "";
                            
($tipo_ped <> "") ? $filtro_tipo = "tipo_ped IN($tipo_ped)" : $filtro_tipo = "";
                                
($conta_ped <> "") ? $filtro_conta = "conta_ped IN($conta_ped)" : $filtro_conta = "";
                                
($status_ped <> "") ? $filtro_status = "status_ped IN($status_ped)" : $filtro_status = "";
                            
$todos_filtros = array($filtro_data, $filtro_valor, $filtro_tipo, $filtro_conta, $filtro_status);
                                
$todos_filtros = implode(' AND ',$todos_filtros);
                                
$consulta = mysql_query("SELECT * FROM pedidos_conf WHERE $todos_filtros ORDER BY $classificacao $ordem");

O fato de usuário poder usar 1 ou até os 5 filtros ao mesmo tempo é que gera o problema, pois quando o IMPLODE for adicionar os AND, ele vai adicionar também onde o filtro não for utilizado(ou seja, que contiver o valor ""), pois foi salva um array com o valor "". O que eu gostaria era excluir estas arrays que possuem o valor "".

Pessoal, desde já, agradeço.

Abraços.

PS.: caso alguém saiba como fazer isto de outra maneira, por favor, não hesite em me falar. :D

Edited by Bruno Aguiar
Link to comment
Share on other sites

3 answers to this question

Recommended Posts

  • 0

Jefferson. Muito obrigado por ter respondido a minha dúvida. Olhei rapidamente o comando que me passou e não vi ele auxiliando a resolver este problema. Porém, o problema já foi resolvido: foi necessário modificar o código para o seguinte:

if($data_inicial_filtro <> "" AND $data_final_filtro <> "") {
    $todos_filtros[] = "data_ped>='$data_inicial_filtro' AND data_ped<='$data_final_filtro'";
}
if($valor_final_filtro <> "") {
    $todos_filtros[] = "valor_ped>='$valor_inicial_filtro' AND valor_ped<='$valor_final_filtro'";
}
if($tipo_ped <> "") {
    $todos_filtros[] = "tipo_ped IN($tipo_ped)";
}
if($conta_ped <> "") {
    $todos_filtros[] = "conta_ped IN($conta_ped)";
}
if($status_ped <> "") {
    $todos_filtros[] = "status_ped IN($status_ped)";
}
$todos_filtros = implode(' AND ',$todos_filtros);
$consulta = mysql_query("SELECT * FROM pedidos_conf WHERE $todos_filtros ORDER BY $classificacao $ordem");

Obrigado!

Link to comment
Share on other sites

  • 0

Bruno,

uma outra solução que utilizo nesse caso é depois de concatenar tudo remover o final;

$todos_filtros = implode(' AND ',$todos_filtros);
$todos_filtros = substr($todos_filtros,0,-4);
Jefferson. Muito obrigado por ter respondido a minha dúvida. Olhei rapidamente o comando que me passou e não vi ele auxiliando a resolver este problema. Porém, o problema já foi resolvido: foi necessário modificar o código para o seguinte:
if($data_inicial_filtro <> "" AND $data_final_filtro <> "") {
    $todos_filtros[] = "data_ped>='$data_inicial_filtro' AND data_ped<='$data_final_filtro'";
}
if($valor_final_filtro <> "") {
    $todos_filtros[] = "valor_ped>='$valor_inicial_filtro' AND valor_ped<='$valor_final_filtro'";
}
if($tipo_ped <> "") {
    $todos_filtros[] = "tipo_ped IN($tipo_ped)";
}
if($conta_ped <> "") {
    $todos_filtros[] = "conta_ped IN($conta_ped)";
}
if($status_ped <> "") {
    $todos_filtros[] = "status_ped IN($status_ped)";
}
$todos_filtros = implode(' AND ',$todos_filtros);
$consulta = mysql_query("SELECT * FROM pedidos_conf WHERE $todos_filtros ORDER BY $classificacao $ordem");

Obrigado!

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Forum Statistics

    • Total Topics
      152.2k
    • Total Posts
      652k
×
×
  • Create New...