Ir para conteúdo

POWERED BY:

Jack Oliveira

Erro ao Atualizar

Recommended Posts

Ola pessoal  boa noite..

Vou tentar explicar aqui o meu problema da melhor forma que der, espero que possam entender...

 

Amigos eu estou tendo um problema em fazer uma atualização 

Bom quando vou cadastrar da sucesso e é gravado normal no banco de dados ate ai esta ok..

 

Seria  o seguinte dentro de um form ele gera linhas ou seja + inputs caso seja preciso entende? Usando javascript´s, quando vou atualizar as informações que esta nas tabelas ou seja

são 3 tabelas 

tbl_department 

dep_id

nome

news etc....

 

tbl_department_openning_hour

hou_id

titulo

time

dep_id  <-- Aqui onde pega o id da tabela tbl_department

 

 

tbl_department_faq

faq_id

titulo

conteudo

dep_id  <-- Aqui onde pega tbm o id da tabela tbl_department

 

Obs: Ele Grava normal no banco de dados, porem quando atualizar que não esta dando certo, e é preciso que seja atualizado todos os input das tabelas tbl_department_faq e tbl_department_openning_hour. Acredito que já entenderam aqui umas das parte que seria preciso.

 

Bom vou posta uma parte do HTML  do FORM para melhor entender o que seria ok!!, Sei que não tem nada a ver com o PHP, mais como tinha dito apenas para melhor entender..

<?php $dep_id = get('EditarItem'); $QueryTblDepartment = DBRead('tbl_department','*',"WHERE dep_id = '{$dep_id}'"); if (is_array($QueryTblDepartment)) { foreach ($QueryTblDepartment as $TblDepartment) { 							                                  									
									?>
									<form method="post" action="?Atualizar=<?= $TblDepartment['dep_id']; ?>" enctype="multipart/form-data">
										<div class="col-md-6">
											<div class="form-group">
												<label>Titulo:</label>
									    		<input class="form-control" name="dep_name" value="<?= $TblDepartment['dep_name']; ?>"  placeholder="Exemplo: Globo City" autocomplete="off" required>
											</div>
											</div>
											<div class="col-md-6">
											<div class="form-group">
												<label>Telefone:</label>
									    		<input class="form-control telefone" name="dep_phone" value="<?= $TblDepartment['dep_phone']; ?>" placeholder="Exemplo: (00) 0000-0000" autocomplete="off">
											</div>
											</div>
											<div class="col-md-6">
											<div class="form-group">
												<label>WhatsApp:</label>
									    		<input class="form-control whatsapp" name="dep_whatsapp" value="<?= $TblDepartment['dep_whatsapp']; ?>" placeholder="Exemplo: (00) 0.0000-0000" autocomplete="off">
											</div>
											</div>
											<div class="col-md-6">
											<div class="form-group">
												<label>Fax:</label>
									    		<input class="form-control" name="dep_fax" value="<?= $TblDepartment['dep_fax']; ?>" placeholder="Exemplo: (00) 0000-0000" autocomplete="off">
											</div>
											</div>
											<div class="form-group">
												<label>Seção de FAQ:</label>
									    	<table id="fqSection" class="table table-bordered table-striped">
									<thead>
										<tr>
											<th style="width:50%;">Titulo</th>
											<th>Contente</th>
											<th>Ação</th>
										</tr>
									</thead>
									<tbody>	
										<?php
                                    //Departamento FAQ
                                    $QueryDepartamentoFaq = DBRead('tbl_department_faq','*',"WHERE dep_id='{$dep_id}'"); if (is_array($QueryDepartamentoFaq)) { foreach ($QueryDepartamentoFaq as $Fa) {
                                        	$arr_fq_id[]      = $Fa['fq_id'];
	                                        $arr_fq_title[]   = $Fa['fq_title'];
	                                        $arr_fq_content[] = $Fa['fq_content'];
									}}						
										
										
										 if(isset($arr_fq_title)):
										for($i=0;$i<count($arr_fq_title);$i++) { 
											?>
											<tr>
												<td>
													<input autocomplete="off" type="text" class="form-control" style="width:100%" name="fq_title" value="<?= $arr_fq_title[$i]; ?>">
												</td>
												<td>
													<textarea class="form-control" cols="30" rows="10" style="width:100%;height:50px;" name="fq_content"><?= $arr_fq_content[$i]; ?></textarea>
												</td>
												<td>
												<span class="btn btn-danger btn-xs"><a onclick="DeletarItem(<?= $arr_fq_id[$i]; ?>, 'DeletarFaq');" href="#!"  style="color: #fff;">Excluir</a></span>
												</td>
											</tr>
											<?php
										//}}
										 }
										endif; 
										?>									
									</tbody>
								</table>
                                <!-- Aqui para criar novos input para serem gravado no banco caso seja preciso  -->              
								<input type="button" class="btn btn-info btn-small" id="btnAddFaq" value="+ Adicionar linha" style="margin-bottom:10px;">
										     </div>	
 						
											<center><hr>
												<button class="btn btn-primary">Atualizar</button>
												<br><br>
											</center>
										</div>
									</form>
									<?php } } ?>                                     

Bom ai esta apenas um pouco do form tem mais coisa que seria igual o que preciso resolver

 

Agora a parte do PHP que preciso resolver, vou posta apenas uma parte para poder entender tbm

 

<?php // Atualizar Item de Departamento
	if (isset($_GET['Atualizar'])) {
				$dep_id = get('Atualizar');

    $fq_empty = 0;
    if( !empty($_POST['fq_title']) && !empty($_POST['fq_content']) ) {
    	$fq_empty = 1;
		foreach ($_POST['fq_title'] as $value) { //Sempre mostra o erro nesta linha
			$arr1[] = $value;
		}
		foreach ($_POST['fq_content'] as $value) { //Sempre mostra o erro nesta linha
			$arr2[] = $value;
		}
		$j=0;
		for($i=0;$i<count($arr1);$i++) { //Sempre mostra o erro nesta linha
			if($arr1[$i]=='' && $arr2[$i]=='') {continue;}
			else {
				$new_arr1[$j] = $arr1[$i];
				$new_arr2[$j] = $arr2[$i];
				$j++;
			}
		}
	}

		
		$AtualizarDepartment = array(
			'dep_name' 	        => post('dep_name'),
			'dep_slug' 		    => UrlAmigavel(post('dep_name')),
			'dep_detail' 		=> post('dep_detail'),
			'dep_address' 		=> post('dep_address'),
			'dep_phone' 		=> post('dep_phone'),
			'dep_whatsapp' 		=> post('dep_whatsapp'),
			'dep_fax' 		    => post('dep_fax'),
			'dep_email' 		=> post('dep_email'),
			'meta_title' 		=> post('dep_name'),
			'meta_keyword' 		=> post('meta_keyword'),
			'meta_description' 	=> LimitarTexto(post('dep_detail'),'200','...')
	

		);

		$QueryTblDepartment = DBUpdate('tbl_department', $AtualizarDepartment, "dep_id = '{$dep_id}'", TRUE);

		 if ($QueryTblDepartment != 0) {
	        Redireciona('?sucesso&Department');
	    } else {
	        Redireciona('?erro&Department');
	    } 
		
		// Atualizar tbl_department_faq
		if($fq_empty == 1) {
			for($i=0;$i<count($new_arr1);$i++) {		
		$TblDepartmentFaq = array(
			'fq_title'   => $new_arr1[$i],
			'fq_content' => $new_arr2[$i],
			'dep_id'     => $dep_id			

		);

		$QueryTblDepartmentFaq = DBUpdate('tbl_department_faq', $TblDepartmentFaq, "dep_id = '{$dep_id}'");
			}
		}	

		 if ($QueryTblDepartmentFaq != 0) {
	        Redireciona('?sucesso&AtualizarFaq');
	    } else {
	        Redireciona('?erro&AtualizarFaq');
	    } 
		
		// Criar Novo input para tbl_department_faq
		if($fq_empty == 1) {
			for($i=0;$i<count($new_arr1);$i++) {		
		$SqlFaq = array(
			'fq_title'   => $new_arr1[$i],
			'fq_content' => $new_arr2[$i],
			'dep_id'     => $QueryTblDepartment			

		);

		$QueryFaq = DBRead('tbl_department_faq', $SqlFaq);
			}
		}		
		

		 if ($QueryFaq != 0) {
	        Redireciona('?sucesso&Faq');
	    } else {
	        Redireciona('?erro&Faq');
	    } 
	}

Neste caso ao mesmo tempo que teria que atualizar a

tbl_department_faq

faq_id

titulo

conteudo

dep_id  <-- Aqui onde pega tbm o id da tabela tbl_department

 

Ele precisa grava caso seja preciso criar nova linha ou seja criar novo input para atualizar junto entende?

 

Pessoal espero que eu tenha sido bem objetivo aqui para que possam entender....

 

Desde já agradeço

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá amigo, tudo bem?

 

Primeiro vamos analisar um trecho do seu código:

// para cada item dentro do array fq_title, me dê seu valor através da var $value
foreach ($_POST['fq_title'] as $value) {
    $arr1[] = $value;// agora crie um array novo e coloque $value em um novo índice
}

// Percebe que esse trecho é redundante?

Agora veja esse exemplo:

<?php
/* Isso é o que você está esperando do Form
   E para ter certeza de que você está recebendo um valor parecido à esse,
   você deveria imprimir o valor de $_POST.
   Isso pode ser feito com print_r ou var_dump, como fiz mais abaixo.
*/
$_POST = [
    'fq_title' => [
        'valor1',
        'valor2',
        'valor3',
        'valor4',
    ]
];

// Aqui inseri o trecho citado na explicação anterior.
foreach ( $_POST['fq_title'] as $value ) {
    $arr1[] = $value;
}

// E aqui exibi as duas informações para comparar o resultado
echo '<pre>';
print_r( $arr1 );
print_r( $_POST[ 'fq_title' ] );
echo '</pre>';

// Veja que o resultado é exatamente igual para ambos os casos:

/**

<pre>Array
(
    [0] => valor1
    [1] => valor2
    [2] => valor3
    [3] => valor4
)
Array
(
    [0] => valor1
    [1] => valor2
    [2] => valor3
    [3] => valor4
)
</pre>

 * /

 

Não analisei o bloco (for) que aparece depois desses foreach, mas me parece que ele poderia ser um pouco mais simples também.

 

Mas o ponto principal do problema, pelo que consigo perceber, está justamente no seu formulário. Perceba que seu input multivalorado fq_title recebe esse atributo:

name="fq_title"

Se enviamos arrays ao PHP, devemos enviar nesse padrão:

name="fq_title[]"

Outra sugestão que me vem à cabeça é aprimorar a indexação das informações, com algo assim:

<input type="text" name="item[0][fq_title]" />
<input type="text" name="item[0][fq_content]" />

<input type="text" name="item[1][fq_title]" />
<input type="text" name="item[1][fq_content]" />

<input type="text" name="item[2][fq_title]" />
<input type="text" name="item[2][fq_content]" />

Talvez assim seja mais prática a manipulação da lógica no PHP depois.

 

Se eu não estou enganado ou entendi mal a questão, acredito que corrigindo esse aspecto você será capaz de progredir na solução do problema.

Caso ainda não consiga, peço que traga-nos as mensagens de erro e informações adicionais. :)

Compartilhar este post


Link para o post
Compartilhar em outros sites

É importante observar ainda que se sua intenção é atualizar os registros, o PHP deverá ter acesso aos IDs de cada uma dessas linhas, então no lugar de item[0], item[1], item[2], seria item[id_do_registro][fq_title].

 

Em casos como esse é comum querermos passar informações de forma transparente (sem conhecimento do usuário), e para isso podemos contar com os campos hidden.

Não acho que seja necessário no seu caso, mas dê uma olhada também: https://www.w3schools.com/tags/att_input_type_hidden.asp

Compartilhar este post


Link para o post
Compartilhar em outros sites

Ola Matheus Tavares Boa noite, obrigado pela resposta..

 

Então fiz assim tbm e não deu certo....

Em 21/05/2021 at 10:20, Matheus Tavares disse:

É importante observar ainda que se sua intenção é atualizar os registros, o PHP deverá ter acesso aos IDs de cada uma dessas linhas, então no lugar de item[0], item[1], item[2], seria item[id_do_registro][fq_title].

 

Em casos como esse é comum querermos passar informações de forma transparente (sem conhecimento do usuário), e para isso podemos contar com os campos hidden.

Não acho que seja necessário no seu caso, mas dê uma olhada também: https://www.w3schools.com/tags/att_input_type_hidden.asp

Nesta parte se tu observar no form que mostrei ira ver como fiz para chamar ou seja tem os id´s relacionado a cada 

 

Ex: 

 

										<?php
                                    //Departamento FAQ
                                    $QueryDepartamentoFaq = DBRead('tbl_department_faq','*',"WHERE dep_id='{$dep_id}'"); if (is_array($QueryDepartamentoFaq)) { foreach ($QueryDepartamentoFaq as $Fa) {
                                        	$arr_fq_id[]      = $Fa['fq_id'];
	                                        $arr_fq_title[]   = $Fa['fq_title'];
	                                        $arr_fq_content[] = $Fa['fq_content'];
									}}						
										
										
										 if(isset($arr_fq_title)):
										for($i=0;$i<count($arr_fq_title);$i++) { 
											?>
											<tr>
												<td>
													<input autocomplete="off" type="text" class="form-control" style="width:100%" name="fq_title" value="<?= $arr_fq_title[$i]; ?>">
												</td>
												<td>
													<textarea class="form-control" cols="30" rows="10" style="width:100%;height:50px;" name="fq_content"><?= $arr_fq_content[$i]; ?></textarea>
												</td>
												<td>
												<span class="btn btn-danger btn-xs"><a onclick="DeletarItem(<?= $arr_fq_id[$i]; ?>, 'DeletarFaq');" href="#!"  style="color: #fff;">Excluir</a></span>
												</td>
											</tr>
											<?php
										//}}
										 }
										endif; 
						
				?>

Aqui onde esta "WHERE dep_id='{$dep_id}' nesta parte ele pega o ID da pagina que esta sendo editando {$dep_id}

 

Entende??

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 violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • 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.