Ir para conteúdo
helkton

Ajuda com Array

Recommended Posts

Olá galera, estou no luta aqui com um cardapio, bom vamos direto ao ponto, preciso de array onde ele consulte la no meu banco de dados os itens desse cardapio, por exemplo no meu banco de dados tenho as tabelas

CATEGORIAS
->ID=1 ===> Categoria ==> Pizzas
->ID=2 ===> Categorias ==> Bebidas
->ID=3 ===> Categorias ==> Doces
->ID=4 ===> Categorias ==> Combo
ITENS_CATEGORIA
ID_CATEGORIA 1 - Pizza Calabresa
ID_CATEGORIA 1 - Pizzas 4 Queijos
ID_CATEGORIA 1 - Pizzas Bacon
ID_CATEGORIA 1 - Pizzas Franco

ID_CATEGORIA 2 - Breja lata
ID_CATEGORIA 2 - Breja Garrafa
ID_CATEGORIA 2 - Coca Mini
e por ai vai entenderam

Manualmente falando consegui fazer isso

$food = array(
‘Pizzas’=>
array(‘Calabresa’,‘4 queijos’,‘Bacon’,‘Frango’,‘Catupiry’),
‘Bebidas’=>
array(‘Coca Lata’,‘Breja’,‘Cerveja Lata’,‘Tubaina’),
‘Combo’=>
array(‘1 Pizza + Refri 2Litros’,‘1 lanche + 1 coca mini’)
);

Só que como consigo fazer isso acima, porem buscadno esses dados dinamicamente lá no meu banco de dados?
como monto esse ARRAY

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá meu povo ainda estou empacado mais ja tive algum progressinho kkkkkk

vou reexplicar

 

tenho duas tabelas no banco de dados mysql -

CATEGORIAS e outra tabela ITENS

as categorias são cadastradas na Tabela CATEGORIAS tipo [1]PIZZAS / [2]BEBIDAS / [3]LANCHES / [4]COMBO e por aí vai....

Já na tabela ITENS o estabelecimento irá cadastrar os itens referentes a cada categoria por exemple:

[1]PIZZAS->Calabresa / [1]Pizzas->Bacon / [1]Pizzas->Frango / [2]Bebidas->Refri / [2]Bebidas->Breja / [2]Bebidas->LatinhasBreja etc etc etc

Agora vem a parte legal montar os array[]

Estou com esse código

<?php
$hostname = 'localhost';
$username = 'root';
$password = '1234';
$database  = 'testes';

$conexao = mysqli_connect("$hostname", "$username", "$password", "$database");

$sql = "SELECT * FROM categoria_itens INNER JOIN categoria_lojas ON (categoria_itens.categoria_id = categoria_lojas.id_categoria)";
$result = $conexao->query($sql);

    foreach ($result as $idx => $dado) {

       $categoria = $dado['categoria'];
       $id_categoria = $dado['id_categoria'];
       $item = $dado['item'];

      $json["cardapio"][] = [
                    "id_categoria" => $id_categoria,
                    "categoria"     => $categoria];
                    
   }

$resul = mb_convert_encoding($json, "utf-8", "LATIN1");

echo json_encode($resul,JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);

echo '<pre>';
print_r($resul);

?>

essa consulta dessa forma esta me retornando desse jeito

Array
(
    [cardapio] => Array
        (
            [0] => Array
                (
                    [id_categoria] => 1
                    [categoria] => Pízzas
                )

            [1] => Array
                (
                    [id_categoria] => 1
                    [categoria] => Pízzas
                )

            [2] => Array
                (
                    [id_categoria] => 1
                    [categoria] => Pízzas
                )

            [3] => Array
                (
                    [id_categoria] => 1
                    [categoria] => Pízzas
                )

            [4] => Array
                (
                    [id_categoria] => 2
                    [categoria] => Bebidas
                )

            [5] => Array
                (
                    [id_categoria] => 2
                    [categoria] => Bebidas
                )

            [6] => Array
                (
                    [id_categoria] => 2
                    [categoria] => Bebidas
                )

            [7] => Array
                (
                    [id_categoria] => 2
                    [categoria] => Bebidas
                )

        )

)

pois bem esta me retornando 1 array com a categoria para cada item cadastrado e isso não é nada bom nhe digamos que eu tenha uns 500 ITENS cadastrados vai virar uma zona da pega kkkkkk

como ajuntar tudo isso e ainda colocar os ITENS cadastrados tudo dentro do array da mesma CATEGORIA tipo assim....

Array
(
    [cardapio] => Array
        (
            [0] => Array(
                    [id_categoria] => 1
                    [categoria] => Pízzas
             [1] = Array(
					[item] => Calabresa
					[item] => Bacon
					[item] => Frango
					[item] => Moda da Casa					
						)
                )



            [1] => Array(
                    [id_categoria] => 2
                    [categoria] => Bebidas
            [2] = Array(
					[item] => Refri
					[item] => Breja
					[item] => LatinhaBreja
					[item] => Dolly					
						)
                )
                
        )

)

bom gente seria mais ou menos isso acho q da pra entender nhe, trocando em miúdos, seria um cardápio de restaurante com  onde teriam as categorias e relativamente referente as categorias seus sub-itens

Pizzas[Calabresa, Bacon, Frango, Catupiry...]

Bebidas[Refri, Breja, Dolly, Latinha...]

Doces[Paçoquinha, Pave, ...]

porem tudo isso vindo lá meu banco de dados

me salvem aí

Compartilhar este post


Link para o post
Compartilhar em outros sites

bom galera estou quase conseguindo só falta alguns detalhes rsss

seguinte tenho esta função que irá pegar a categoria e consequentemente as sub-categorias, porem só me tras as categorias e não as sub-categorias

private void prepareLista(){
    lstGrupos = new ArrayList<String>();
    lstItensGrupo = new HashMap<String, List<Produto>>();

    StringRequest stringRequest = new StringRequest(Request.Method.GET, URL,
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    try{
                        JSONArray pro = new JSONArray(response);
                        for(int i = 0; i<pro.length();i++){

                            JSONObject proObj = pro.getJSONObject(i);
                            lstGrupos.add(proObj.getString("categoria"));//Categoria


                            JSONArray itemArray = new JSONArray(response);
                            List<Produto> foods = new ArrayList<>();
                            for(int j=0; j<itemArray.length(); j++){
                                foods.add(new Produto(proObj.getString("categoria"),17.9));
                            }

                               //List<Produto> foods = new ArrayList<>();//Itens_Da_Categoria
                               //foods.add(new Produto(proObj.getString("item"), 15.5));

                                lstItensGrupo.put(lstGrupos.get(i),foods);
                        }
                        //cria um adaptador (BaseExpandableListAdapter) com os dados acima
                        listAdapter = new ExpandableListViewAdapter(MainActivity.this, lstGrupos, lstItensGrupo);
                        //define o apadtador do ExpandableListView
                        expListView.setAdapter(listAdapter);
                    }catch (JSONException e){
                        e.printStackTrace();
                    }
                }
            },
            new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {
                    Toast.makeText(MainActivity.this, error.getMessage(), Toast.LENGTH_LONG).show();
                }
            });
    Volley.newRequestQueue(this).add(stringRequest);
}

isso é aplicativo android o meu array está saindo assim

Array
(
    [0] => Array
        (
            [id_categoria] => 1
            [categoria] => Pízzas
            [0] => Array
                (
                    [0] => Array
                        (
                            [categoria_id] => 1
                            [item] => 4 Queijos
                        )

                    [1] => Array
                        (
                            [categoria_id] => 1
                            [item] => Calabresa
                        )

                )

        )

    [1] => Array
        (
            [id_categoria] => 2
            [categoria] => Bebidas
            [ite] => Array
                (
                )

        )

    [2] => Array
        (
            [id_categoria] => 3
            [categoria] => Doces
            [ite] => Array
                (
                )

        )

    [3] => Array
        (
            [id_categoria] => 4
            [categoria] => Combo
            [ite] => Array
                (
                )

        )

)

ele me tras as [categorias] - - Pizzas - Bebidas - Doces - Combo,

porém as sub-categorias relacionadas não pega, alguma alma caridosa poderia me dar uma luz rsss

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 Jonas Ribeiro Nascimento
      Estou criando meu próprio mvc php para adquirir mais conhecimento.
      Mas estou me deparando com uma coisa muita estranha, eu perco a $_SESSION de uma view para outra view
      Fiz um codigo simples pra testar.a.php ----- view a.php
      <?php session_start(); $_SESSION['teste'] = 'Funcionou'; echo $_SESSION['teste']; ?> <?php session_start(); echo $_SESSION['teste']; // Notice: Undefined variable: _SESSION in var_dump($_SESSION); // Notice: Undefined variable: _SESSION in NULL ?> <?php namespace Sis\Classes; use App\Model\ClassLogin; use Sis\Traits\TraitGetIp; class ClassSession { private $login; private $timeSession = 1200; private $timeCanary = 300; public function __construct(){ if(session_id() == ''){ ini_set("session.save_handler", "files"); //Cabeçalhos somente atraves de arquivos ini_set("session.use_cookies", 1); //Habilita o uso de cookies ini_set("session.use_only_cookies", 1); //Só pode habilitar a seção atraves de coockies ini_set("session.cookie_domain", DOMAIN); //Só aceita coockies vindo do nosso sistema ini_set("session.cookie_httponly", 1); //Só aceita script php e não deixa o javascript alterar o sistema if(DOMAIN != "localhost"){ ini_set("session.cookie_secure", 1); //Para trabalhar com o SSL do servidor ativo } /*Criptografia das nossas sessions*/ ini_set("session.entropy_length", 512); // ini_set("session.entropy_file","/dev/urandom"); ini_set("session.hash_function", "sha256"); ini_set("session.hash_bits_per_character", 5); session_start(); } $this->login = new ClassLogin(); } #Proteger contra roubo de sessão public function setSessionCanary($par=null){ session_regenerate_id(true); if($par == null){ $_SESSION['canary']=[ "birth" => time(), "IP" => TraitGetIp::getUserIp() //Pega o ip do usuario ]; }else{ $_SESSION['canary']['birth']=time(); } } #Verificar a integridade da sessão public function verifyIdSessions(){ if(!isset($_SESSION['canary'])){ $this->setSessionCanary(); } if($_SESSION['canary']['IP'] !== TraitGetIp::getUserIp()){ $this->destructSessions(); $this->setSessionCanary(); } if($_SESSION['canary']['birth'] < time() - $this->timeCanary){ $this->setSessionCanary("Time"); } } #Setar as sessões do nosso sistema public function setSessions($Email){ $this->verifyIdSessions(); $_SESSION['Login'] = true; $_SESSION['Time'] = time(); $_SESSION['Nome'] = $this->login->getIssetSession($Email)['data']['Nome']; $_SESSION['Email'] = $this->login->getIssetSession($Email)['data']['Email']; $_SESSION['Permissoes'] = $this->login->getIssetSession($Email)['data']['Permissoes']; } #Validar as páginas internas do sistema public function verifyInsideSession(){ $this->verifyIdSessions(); if(!isset($_SESSION['Login']) || !isset($_SESSION['Permissoes']) || !isset($_SESSION['canary'])){ $this->destructSessions(); header("Location: ".DIRPAGE."NaoAutorizado"); }else{ if($_SESSION['Time'] >= time() - $this->timeSession){ $_SESSION['Time']=time(); }else{ $this->destructSessions(); header("Location: ".DIRPAGE."NaoAutorizado"); } } } #Destruir as sessions existentes public function destructSessions(){ foreach (array_keys($_SESSION) as $key) { unset($_SESSION[$key]); } } #testar public function testarSessions(){ echo 'oiiiiiiiiiiiiiiiiiiiiiiooooooooooo'; } }

    • Por Allan Carlos dos Santos G
      Bom dia Pessoal, Gostaria de saber como Instalar e colocar pra rodar a versão do Zend PHP 1.11.11, tenho tido dificuldade de achar material na internet e se puderem ajudar, obrigado!
    • Por Perroni91
      Olá pessoal.
      Estou com uma dúvida, mas como sou leiga no mysql, não estou conseguindo resolver.
       
      Tenho duas tabelas no meu banco de dados:
       
      Posts
      id
      titulo_principal
      categoria_id
      imagem
       
      Categorias
      id
      categoria
       
      ---

      Já cadastrei as categorias 'HTML' e 'CSS', e cada um contêm 1 post de cada.

      O que eu gostaria era que: A cada vez que criar um post em alguma dessas categorias, mostrar a quantidade separadamente.

      Ficaria assim:
      HTML               3
      CSS                   1


      Alguém poderia me ajudar, por favor?
      Estou quebrando a cabeça tentando fazer isso e não consegui.
      Obrigada!
    • Por Rogerio Pancini
      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.
       
×

Informação importante

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