Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
Entre para seguir isso  
Eder Cuer

[Resolvido] Inserir vários checkbox no banco Mysql

Recommended Posts

Olá pessoal aqui estou de novo :muro: procurei muito e não resolvi...

Deixa eu explicar, eu tenho 2 tabelas que se relacionam, mrh(microrregião) e transportadora, nessa relação foi gerada uma outra tabela mrh_transportadora, na qual eu tenho (cod_mrh, cod_transp).

No meu formulário estou fazendo um while para mostrar a microrregião de certo estado, e todas em checkbox.


<?php
include ("connect.php");
$consul=mysql_query("SELECT cod_mrh,nome FROM mrh WHERE cod_estado = 4");

while ($dado = mysql_fetch_array($consul)) {
echo "<input type='checkbox' name='mrh[]' id='".htmlentities($dado['nome'])."' value='".htmlentities($dado['cod_mrh'])."' />" .htmlentities($dado['nome'])." " ;
}
?>

O problema seria o seguinte, o usuário ta cadastrando uma transportadora, ai nos checkbox ele vai escolher quais microrregiões a sua transportadora atende.

Como faço pra pegar os valores e inserir na minha tabela?

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • Autor do tópico
  • Eu fiz o seguinte:



    $sql2 = "SELECT cod_transp FROM transportadora WHERE cnpj='$cnpj'";
    $res = mysql_query($sql2);


    $dados = mysql_fetch_array($res);

    $id = $dados['cod_transp'];

    foreach($_POST['mrh'] as $value){
    echo $value;
    $insert = mysql_query("INSERT INTO mrh_transportadora VALUES ('$id', '$value')");
    }

    Mas não está inserindo os vários registros, registra só 1.

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Quais os "name"s dos campos que você criou no formulário ?

    Posta o código do seu form..

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites
  • Autor do tópico
  • Eae Mog.Lucas, estou montando os checks via banco com php, da uma olhada:


    <?php
    include ("connect.php");
    $consul=mysql_query("SELECT cod_mrh,nome FROM mrh WHERE cod_estado = 4");

    while ($dado = mysql_fetch_array($consul)) {
    echo "<input type='checkbox' name='mrh[]' id='".htmlentities($dado['nome'])."' value='".htmlentities($dado['cod_mrh'])."' />" .htmlentities($dado['nome'])." " ;
    }
    ?>

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Na parte que você faz o insert, tem um echo $value.. ele tá retornando todos os checks ? ou só executa o loop 1x?

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites
  • Autor do tópico
  • Ele ta retornando todos os valores selecionados.

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    pela minha logica.. no seu banco de dados deve de haver uma tabela N:N onde você armazena apenas ids

    por exemplo transportadora X atende as microregioes a, b, c e d

    você tem uma tabela transportadora

    1 X

    e tabela microregiao

    1 a

    2 b

    3 c

    4 d

    no seu formulario você marca a transportadora X , para as microregioes a e d

    você teria que inserir os dados nesta tabela N:N entre transportadora e microregiao ficando assim:


    idRegistro idTransp idmicroR
    1 1 1
    2 1 4

    bem esta é aparte logica da coisa é o que eu entendi..

    agora o seu problema:

    você teria que pegar os valores das IDs e armazena-las em um vetor atribindo a uma key

    porque tipo você tem a ID da transportadora que ela pode receber um outro vetor de keys.

    exemplo:


    $transportadora = $_POST["codTransp"];
    $microregioes = $_POST["codmicro"];
    $itens = array($transportadora =>array($microregioes));

    foreach($itens as $it => $key){
    echo $it . " - " $key;
    }

    então.. você percorrendo o vetor que contém a transportadora atribuida com as ids de cada micro regiao... você pode dar um explode para separar..

    e então encaixar em um insert into para você colocar na tabela N:N

    nao sei se fui bem claro.. lembrando que estes meus codigos foram só exemplos e podem conter erros.. eu nao testei eles.. mas so servem de tipo de guia para você tentar resolver seu problema.

    lembre-se como você esta tratando com vetor no seu formulario.. então no php você tem que jogar os dados em um vetor e percorre-los

    abraço

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites
  • Autor do tópico
  • É isso mesmo Dif, você entendeu a parte do relacionamento.

    Mas ali no meu código eu já não estou colocando os dados em um array com o mysql_fetch_array?

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    pois é.. eu vi ali que você ja coloca num vetor.

    de alguma forma você precisa percorrer o vetor de checkbox.. de repente fazer um for pode ser uma solução..

    por exemplo:


    for ($i=0; $i<count($_POST['checkbox']);$i++) {
    echo "<br />value $i = ".$_POST['checkbox'][$i];
    }

    outra possivel solução.. seria você tentar usar o a funçao serialize() do php que tem como finalidade transformar um objeto em uma string.. pode usar usada pra transformar um array em string também nao digo que é a melhor solução mas pode funcionar

    +- assim:


    <?php
    $mrh = serialize($_POST['mrh']);

    $query = "INSERT INTO table(mrh) values($mrh)";
    mysql_query($query) or die(mysql_error());
    ?>

    enfim.. vamos tentando ate conseguir o esquema é nao desistir!

    Editado por dif

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites
  • Autor do tópico
  • Aeeeee consegui resolver :lol:

    Coisa besta que nem tinha percebido

    Tipo... meu código de inserção tava assim:


    foreach($_POST['mrh'] as $value){
    echo $value;
    $insert = mysql_query("INSERT INTO mrh_transportadora VALUES ('$id', '$value')");
    }

    Bom...ali em cima eu estava inserindo o código da transportadora depois da mrh, mas na minha tabela é o contrario, primeiro a mrh e depois o codigo da transportadora. E não sei se é por isso também, mas eu não estava colocando os campos da minha tabela.

    Só inventi os valores e coloquei os campos:


    foreach($_POST['mrh'] as $value){
    echo $value;
    $insert = mysql_query("INSERT INTO mrh_transportadora(cod_mrh, cod_transp) VALUES ('$value', '$id')");
    }

    E funcionou de boa :lol:

    Ae Dif valeu mais uma vez, sempre me ajudando ;)

    Valeu também Mog.Lucas

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Caso o autor do tópico necessite, o mesmo será reaberto, para isso deverá entrar em contato com a moderação solicitando o desbloqueio.

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites
    Visitante
    Este tópico está impedido de receber novos posts.
    Entre para seguir isso  





    Sobre o Clube do Hardware

    No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações sobre tecnologia do Brasil. Leia mais

    Direitos autorais

    Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

    ×