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, 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
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer ao auxílio dos amigos, mas preciso entender e resolver um problema.
       
      Tenho uma Rotina que o usuário seleciona os produtos que deseja para requerer ao setor responsável.
       
      O usuário escolhe um produto qualquer e Clicla em um button para incluir a lista.

      O problema que estou enfrentando é que após escolher o produto e teclar ENTER o Sistema já salva no BD.
       
      Gostaria de criar uma Tecla de Atalho, para quando incluir/escolher o produto na lista, o usuário tecla como exemplo:
      ALT+A  para agregar a lista
      ALT+S para salvar a lista de itens desejados.

      Assim, quando teclar enter, o sistema não dispara o GRAVAR na Base de Dados.

      Grato,

      Cesar
       
       
       
×

Informação importante

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