Jump to content
Good

Estrutura de um sistema de criar loja virtual

Recommended Posts

Boa noite,

 

estou com dúvidas e estive pensando... se eu fosse criar um sistema de criar lojas virtuais, como poderia ser a estrutura, principalmente nesta parte:

- um banco de dados para cada loja ou um banco de dados para todas as lojas?

 

Que seria separado apenas por id de loja, pedidos seriam unicamente visto por cada loja, óbvio...

 

Qual a sua opinião sobre isto?

Share this post


Link to post
Share on other sites

@Good

 

Em questão de praticidade e implementação de código a melhor opção seria um banco para todas as lojas.

 

Mas existe o lado performatico, imagine que cada loja tenha 10 Gigas de informação e você tenha pelo menos 200 lojas.

Então teremos um banco de dados com 2 Teras de informação, agora com esse exemplo o que é mais rápido procurar, 1 registro dentro de 10 Gigas de informação, ou buscar 1 registro dentro de 2 Teras de informação?

 

Então em questão de performance é muito melhor você ter um banco de dados para cada loja. melhorando a resposta, na verdade é muito melhor você ter 1 Banco de Dados COM 1 TABELA para cada LOJA VIRTUAL ou N tabelas para cada loja, eu "prefixaria" cada tabela.

 

Com isso eu tenho um Banco de Dados "gigante", mas uma loja completamente apartada de outra loja, o que em questão de performance é muito mais performatico com o passar do tempor, mas é necessário ver todas as limitações do lado do servidor, tamanho disponível, limitações de tabelas e tudo mais...

 

EU criaria uma lógica para que existisse 1 DB_LOJAS prefixando os nomes das tabelas, exemplo para tabelas USUARIO, PRODUTOS, CLASSIFICADO e PROMOÇÃO.

 

1 - DB_LOJAS

    1 - TB_%nomeLojaVirtual%_USUARIO

    1 - TB_%nomeLojaVirtual%_PRODUTOS

    1 - TB_%nomeLojaVirtual%_CLASSIFICADOS

    1 - TB_%nomeLojaVirtual%_PROMOCAO

 

1 - DB_LOJAS

Loja KABUM

    2 - TB_KABUM_USUARIO

    2 - TB_KABUM_PRODUTOS

    2 - TB_KABUM_CLASSIFICADOS

    2 - TB_KABUM_PROMOCAO

 

1 - DB_LOJAS

Loja Megamamute

    3 - TB_MEGAMAMUTE_USUARIO

    3 - TB_MEGAMAMUTE_PRODUTOS

    3 - TB_MEGAMAMUTE_CLASSIFICADOS

    3 - TB_MEGAMAMUTE_PROMOCAO

 

1 - DB_LOJAS

Loja Magazine Luiza

    4 - TB_MAGAZINELUIZA_USUARIO

    4 - TB_MAGAZINELUIZA_PRODUTOS

    4 - TB_MAGAZINELUIZA_CLASSIFICADOS

    4 - TB_MAGAZINELUIZA_PROMOCAO


Etc...

 

Mas programação é a gosto de cada um.

Espero ter ajudado.

 

Att.

Felipe Coutinho

 

Share this post


Link to post
Share on other sites
56 minutos atrás, Felipe Guedes Coutinho disse:

@Good

 

Em questão de praticidade e implementação de código a melhor opção seria um banco para todas as lojas.

 

Mas existe o lado performatico, imagine que cada loja tenha 10 Gigas de informação e você tenha pelo menos 200 lojas.

Então teremos um banco de dados com 2 Teras de informação, agora com esse exemplo o que é mais rápido procurar, 1 registro dentro de 10 Gigas de informação, ou buscar 1 registro dentro de 2 Teras de informação?

 

Então em questão de performance é muito melhor você ter um banco de dados para cada loja. melhorando a resposta, na verdade é muito melhor você ter 1 Banco de Dados COM 1 TABELA para cada LOJA VIRTUAL ou N tabelas para cada loja, eu "prefixaria" cada tabela.

 

Com isso eu tenho um Banco de Dados "gigante", mas uma loja completamente apartada de outra loja, o que em questão de performance é muito mais performatico com o passar do tempor, mas é necessário ver todas as limitações do lado do servidor, tamanho disponível, limitações de tabelas e tudo mais...

 

EU criaria uma lógica para que existisse 1 DB_LOJAS prefixando os nomes das tabelas, exemplo para tabelas USUARIO, PRODUTOS, CLASSIFICADO e PROMOÇÃO.

 

1 - DB_LOJAS

    1 - TB_%nomeLojaVirtual%_USUARIO

    1 - TB_%nomeLojaVirtual%_PRODUTOS

    1 - TB_%nomeLojaVirtual%_CLASSIFICADOS

    1 - TB_%nomeLojaVirtual%_PROMOCAO

 

1 - DB_LOJAS

Loja KABUM

    2 - TB_KABUM_USUARIO

    2 - TB_KABUM_PRODUTOS

    2 - TB_KABUM_CLASSIFICADOS

    2 - TB_KABUM_PROMOCAO

 

1 - DB_LOJAS

Loja Megamamute

    3 - TB_MEGAMAMUTE_USUARIO

    3 - TB_MEGAMAMUTE_PRODUTOS

    3 - TB_MEGAMAMUTE_CLASSIFICADOS

    3 - TB_MEGAMAMUTE_PROMOCAO

 

1 - DB_LOJAS

Loja Magazine Luiza

    4 - TB_MAGAZINELUIZA_USUARIO

    4 - TB_MAGAZINELUIZA_PRODUTOS

    4 - TB_MAGAZINELUIZA_CLASSIFICADOS

    4 - TB_MAGAZINELUIZA_PROMOCAO


Etc...

 

Mas programação é a gosto de cada um.

Espero ter ajudado.

 

Att.

Felipe Coutinho

 

 

 

Ajudou muito.. obrigado por tirar um tempo.. vou analisar, pois comprei um sistema recentemente e vi que cada uma tem um banco de dados diferente. 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By victor.dsz
      Boa tarde!
      Preciso de ideia ou até exemplo de algum código que simule o funcionamento das camadas de rede segundo o modelo OSI. Tenho um projeto e a ideia é apresentar as informações deste modelo sem que pareça um slide. Exemplo: Desenvolvemos um PHP um código que simula o envio da mensagem e a detecção de erros pelo método CRC. Estava pensando em algum código que pudesse animar algum objeto do meu site, tipo, fazer ele passar de camada em camada com uma explicação. 
       
      Desde já, 
      grato!
       
      Aqui algumas imagens de como estamos fazendo: (ainda se parece com um slide)
       

       

       

    • By victor.dsz
      Boa tarde!
      Preciso de ideia ou até exemplo de algum código que simule o funcionamento das camadas de rede segundo o modelo OSI. Tenho um projeto e a ideia é apresentar as informações deste modelo sem que pareça um slide. Exemplo: Desenvolvemos um PHP um código que simula o envio da mensagem e a detecção de erros pelo método CRC. Estava pensando em algum código que pudesse animar algum objeto do meu site, tipo, fazer ele passar de camada em camada com uma explicação. 
       
      Desde já, 
      grato!
       
      Aqui algumas imagens de como estamos fazendo: (ainda se parece com um slide)
       

       

       

    • By granderodeo
      <!-------------------------------- PEDIDOS -------------------------> <div class="table-responsive mt-2"> <table class="table table-bordered table-striped text-center"> <thead> <tr> <td colspan="8"> <h4 class="text-center text-info m-0">Pedidos realizados</h4> </td> </tr> <tr> <th>ID pedido</th> <th>Nome cliente</th> <th>E-mail</th> <th>Endereço</th> <th>Número da casa</th> <th>Referência</th> <th>ID cliente</th> </tr> </thead> <tbody> <?php require 'conexao_pedidos.php'; $stmt = $conn->prepare("SELECT * FROM orders"); $stmt->execute(); $result = $stmt->get_result(); $grand_total = 0; while($row = $result->fetch_assoc()): ?> <tr> <td> <?= $row['order_id'] ?></td> <td> <?= $row['order_name'] ?></td> </td> <td><?= $row['order_email'] ?> </td> <td> <?= $row['order_endereco'] ?> </td> <td> <?= $row['order_numero'] ?> </td> <td><?= $row['order_referencia'] ?></td> <td><?= $row['id_usuario'] ?> </td> <td> <button type="button" class="btn btn-danger" data-toggle="modal" data-target="#exampleModal<?= $row['order_id'] ?>"> <i class="fa fa-info-circle"></i> Produtos </button> </td> </tr> <?php endwhile; ?> </tbody> </table> </div> <?php require 'conexao_pedidos.php'; $stmt = $conn->prepare("SELECT * FROM orders"); $stmt->execute(); $result = $stmt->get_result(); $grand_total = 0; while($row = $result->fetch_assoc()): ?> <div class="modal fade" id="exampleModal<?= $row['order_id'] ?>" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true"> <div class="modal-dialog" role="document"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="exampleModalLabel">Modal title</h5> <button type="button" class="close" data-dismiss="modal" aria-label="Close"> <span aria-hidden="true">×</span> </button> </div> <div class="modal-body"> <?= $row['order_id'] ?> </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button> <button type="button" class="btn btn-primary">Save changes</button> </div> </div> </div> </div> <?php endwhile; ?>  
    • By granderodeo
      Tenho as tabelas 'orders' e 'orders_items'. Quando o cliente faz o pedido no site, com nome, endereço, telefone etc, os dados vão para a tabela orders, já os produtos que o cliente pediu vão para a tabela 'orders_items'. A forma que achei de saber qual pedido é de qual cliente, foi dando um id para cada pedido, e inserindo esse mesmo id em ambas tabelas. Agora estou há fazer um painel administrativo para ter uma melhor visibilidade dos pedidos. O que eu fiz no painel, foi exibir todos os pedidos com as informações, e ao lado de cada pedido um botão que exibirá os produtos pedidos por aquele usuário, inclusive vou deixar imagem de como está. Só que quando eu clicar em produtos, mostre somente os produtos comprados por aquele usuário, que como eu disse anteriormente está 'controlado por ID pedido'. Então quero pegar os dados da tabela 'orders_items' relacionados ao tal cliente, me perdoem se não expliquei direito, mas acredito que dê para entender. 
       
      <body> <!-------------------------------- PEDIDOS -------------------------> <div class="table-responsive mt-2"> <table class="table table-bordered table-striped text-center"> <thead> <tr> <td colspan="8"> <h4 class="text-center text-info m-0">Pedidos realizados</h4> </td> </tr> <tr> <th>ID pedido</th> <th>Nome cliente</th> <th>E-mail</th> <th>Endereço</th> <th>Número da casa</th> <th>Referência</th> <th>ID cliente</th> <!------ REMOVER TODOS ITENS DO CARRINHO -----> <!------ FIM REMOVER TODOS ITENS DO CARRINHO -----> </tr> </thead> <tbody> <?php require 'conexao_pedidos.php'; $stmt = $conn->prepare("SELECT * FROM orders"); $stmt->execute(); $result = $stmt->get_result(); $grand_total = 0; while($row = $result->fetch_assoc()): ?> <tr> <td> <?= $row['order_id'] ?></td> <!-- ID do produto do BD para o carrinho --> <td> <?= $row['order_name'] ?></td> </td> <td><?= $row['order_email'] ?> </td> <td> <?= $row['order_endereco'] ?> </td> <td> <?= $row['order_numero'] ?> </td> <!---- Aumentar ou Diminuir a quantidade do produto -----> <td><?= $row['order_referencia'] ?></td> <!---- Aumentar ou Diminuir a quantidade do produto -----> <!---- Fim Aumentar ou Diminuir a quantidade do produto -----> <td><?= $row['id_usuario'] ?> </td> <!-- preço total do carrinho --> <!------- REMOVER ITEM DO CARRINHO ------> <td> <button type="button" class="btn btn-danger" data-toggle="modal" data-target="#exampleModal"> <i class="fa fa-info-circle"></i> Produtos </button> </td> <!------- FIM ITEM REMOVER DO CARRINHO -------> </tr> <?php endwhile; ?> </tbody> </table> </div>  

×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.