Rogerio Pancini Pereira
Coleta de dados para criar uma variável
14 de February de 2019 às 11:12AM
Bom dia pessoal!

Estou com seguinte caso: preciso fazer uma coleta de dados, que no caso seria esta seleção:

$sql_c_1 = mysqli_query($config, "SELECT DISTINCT id_malote FROM boletosdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_1) <= '0'){
$c_sql_c_1[] = "";
}else{
while($r_sql_c_1 = mysqli_fetch_array($sql_c_1)){
$c_sql_c_1[] = $r_sql_c_1[0];
}
}

$sql_c_2 = mysqli_query($config, "SELECT DISTINCT id_malote FROM caixasdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_2) <= '0'){
$c_sql_c_2[] = "";
}else{
while($r_sql_c_2 = mysqli_fetch_array($sql_c_2)){
$c_sql_c_2[] = $r_sql_c_2[0];
}
}

$sql_c_3 = mysqli_query($config, "SELECT DISTINCT id_malote FROM notasfiscaisdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_3) <= '0'){
$c_sql_c_3[] = "";
}else{
while($r_sql_c_3 = mysqli_fetch_array($sql_c_3)){
$c_sql_c_3[] = $r_sql_c_3[0];
}
}

$sql_c_4 = mysqli_query($config, "SELECT DISTINCT id_malote FROM documentosdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_4) <= '0'){
$c_sql_c_4[] = "";
}else{
while($r_sql_c_4 = mysqli_fetch_array($sql_c_4)){
$c_sql_c_4[] = $r_sql_c_4[0];
}
}

$sql_c_5 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_cheque_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_5) <= '0'){
$c_sql_c_5[] = "";
}else{
while($r_sql_c_5 = mysqli_fetch_array($sql_c_5)){
$c_sql_c_5[] = $r_sql_c_5[0];
}
}

$sql_c_6 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_holerite_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_6) <= '0'){
$c_sql_c_6[] = "";
}else{
while($r_sql_c_6 = mysqli_fetch_array($sql_c_6)){
$c_sql_c_6[] = $r_sql_c_6[0];
}
}

$sql_c_7 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_material_grafico_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_7) <= '0'){
$c_sql_c_7[] = "";
}else{
while($r_sql_c_7 = mysqli_fetch_array($sql_c_7)){
$c_sql_c_7[] = $r_sql_c_7[0];
}
}

$sql_c_8 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_outros_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_8) <= '0'){
$c_sql_c_8[] = "";
}else{
while($r_sql_c_8 = mysqli_fetch_array($sql_c_8)){
$c_sql_c_8[] = $r_sql_c_8[0];
}
}

$sql_c_9 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_dinheiro_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_9) <= '0'){
$c_sql_c_9[] = "";
}else{
while($r_sql_c_9 = mysqli_fetch_array($sql_c_9)){
$c_sql_c_9[] = $r_sql_c_9[0];
}
}

$sql_c_10 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_dep_pessoal_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config));

if(@mysqli_num_rows($sql_c_10) <= '0'){
$c_sql_c_10[] = "";
}else{
while($r_sql_c_10 = mysqli_fetch_array($sql_c_10)){
$c_sql_c_10[] = $r_sql_c_10[0];
}
}

Eu até fiz teste com arrays.
Se eu der um implode, consigo fazer o select que preciso:

if(!empty($c_sql_c_1)){
$v_c_sql_c_1 = implode(",",$c_sql_c_1);
}else{
$v_c_sql_c_1 = "";
}

$sql_3 = mysqli_query($config, "SELECT ma.id, ma.titulo, ma.datadecadastro, usr.nome, ma.id_estabelecimento_origem, ma.id_estabelecimento_destino, ma.status, ma.id_usuario_envio FROM malote ma LEFT JOIN usuario AS usr ON (ma.id_usuario_envio = usr.id) WHERE
ma.id_estabelecimento_origem = '$id_estabelecimento' && ma.id_usuario_cadastro = '$id_usuario' OR
ma.id_estabelecimento_destino = '$id_estabelecimento' && ma.id_usuario_cadastro = '$id_usuario' OR
ma.status = '1' && ma.id_estabelecimento_origem = '$id_estabelecimento' OR
ma.status = '2' && ma.id_estabelecimento_origem = '$id_estabelecimento' OR
ma.status = '1' && ma.id_estabelecimento_destino = '$id_estabelecimento' OR
ma.status = '2' && ma.id_estabelecimento_destino = '$id_estabelecimento'

OR ma.id IN ($v_c_sql_c_1)

ORDER BY ma.datadecadastro DESC") or die(mysqli_error($config));
}

Porém, eu precisaria fazer o select com todos os resultados acima.

Fiz outro teste, concatenando todos:

echo $v_c_sql_c_1 . " " . $v_c_sql_c_2 . " " . $v_c_sql_c_3 . " " . $v_c_sql_c_4 . " " . $v_c_sql_c_5 . " " . $v_c_sql_c_6 . " " . $v_c_sql_c_7 . " " . $v_c_sql_c_8 . " " . $v_c_sql_c_9 . " " . $v_c_sql_c_10;

E o resultado foi esse:

312,317 312,317,324 312

Apesar de não estar bonito, se funcionasse poderia ser assim, mas o $sql_3 não lê, por ter espaços sem vírgula, além do resultado estar errado, por ter id's repetidos.

Se alguém tiver alguma ideia da forma mais correta de chegar ao resultado final, eu agradeço.
Pensei em formar um array, com o array_merge, mas não deu certo também.
Enfim, a ideia é juntar todos os resultados, de forma não repetida, para incluir no $sql_3.

Obrigado pela atenção.
Você precisa estar logado no PHPBrasil.com para poder enviar mensagens para os nossos fóruns.

Faça o login aqui.