Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

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

  • Conteúdo Similar

    • Por ILR master
      Fala galera, tudo certo?
       
      Seguinte: No servidor A estou tentando fazer uma consulta com o servidor B, mas está dando erro.
      Estou usando o mesmo código de conexão do servidor B que funciona perfeitamente, mas no servidor A, dá erro.
      Segue código:
       
      $host = 'servidor B';
      $user = 'user';
      $pass = '********';
      $db   = 'banco';
       
      // conexão e seleção do banco de dados
      $conexao = mysqlI_connect($host, $user, $pass, $db);
      mysqlI_set_charset($conexao,"utf8");
      //print "Conexão rodando e OK!"; 
      //mysqlI_close($conexao);
       
      Alguém pode me ajudar?
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
×

Informação importante

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