Ir para conteúdo
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 daemon
      Estou com uma dúvida,
       
      Eu tenho uma rotina que faz uma leitura do arquivo .xml de vários sites.

      Eu consigo pegar o tópico e a descrição, porém gostara de mostrar a imagem que esta na pagina do link.
       
      É possível eu colocar na minha index o url, e aparecer uma preview da imagem que esta no link ? 
       
      Igual o google: https://news.google.com/topics/CAAqKggKIiRDQkFTRlFvSUwyMHZNRGx1YlY4U0JYQjBMVUpTR2dKQ1VpZ0FQAQ?hl=pt-BR&amp;gl=BR&amp;ceid=BR%3Apt-419
       
      No caso eu importo o tópico e descrição, porém não consigo deixar essa imagem na pagina principal.
    • Por violin101
      Caros amigos, saudações.

      Estou com uma dúvida:
      Como consigo fazer uma rotina no sistema onde possa fazer de forma automática trazer o resultado de entrada de produtos a cada 3 meses, por exemplo:

      Produtos --- Entrada ---  Meses
      Prod_A -------- 100 ------ 01/2024
      Prod_A -------- 120 ------ 03/2024
      Prod_A -------- 105 ------ 04/2024
      =========================
      Prod_B -------- 105 ------ 02/2024
      Prod_B -------- 120 ------ 03/2024
      Prod_B -------- 130 ------ 04/2024
      =========================
      ETC
       
      Como consigo mostrar para o usuário esse movimento de entrada a cada 3 meses ?

      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Peço desculpa em recorrer a ajuda dos amigos, pois está sendo um mistério para mim, configurar o meu sistema para Impressão de XML e NFe.

      Quando acrescento as linhas no início do Controller:
      use NFePHP\NFe\Make;
      use NFePHP\NFe\Tools;
      use NFePHP\NFe\Danfe;
      etc, etc.
       
       e chamo a libraries assim em alguma função:  $nfe = new Make(); e etc. <== o sistema acusa que não consegue achar 
       
      fiz as alterações necessárias no autoload
      /* |-------------------------------------------------------------------------- | Composer auto-loading |-------------------------------------------------------------------------- | | Enabling this setting will tell CodeIgniter to look for a Composer | package auto-loader script in application/vendor/autoload.php. | | $config['composer_autoload'] = TRUE; | | Or if you have your vendor/ directory located somewhere else, you | can opt to set a specific path as well: | | $config['composer_autoload'] = '/path/to/vendor/autoload.php'; | | For more information about Composer, please visit http://getcomposer.org/ | | Note: This will NOT disable or override the CodeIgniter-specific | autoloading (application/config/autoload.php) */ $config['composer_autoload'] = './vendor/autoload.php';  
      o meu composer.json está assim:
      { "description": "The CodeIgniter framework", "name": "codeigniter/framework", "type": "project", "homepage": "https://codeigniter.com", "license": "MIT", "support": { "forum": "http://forum.codeigniter.com/", "wiki": "https://github.com/bcit-ci/CodeIgniter/wiki", "irc": "irc://irc.freenode.net/codeigniter", "source": "https://github.com/bcit-ci/CodeIgniter" }, "require": { "php": ">=5.3.7", "mpdf/mpdf": "^7.1", "nfephp-org/sped-nfe": "^5.0", "nfephp-org/sped-da": "^1.0" }, "suggest": { "paragonie/random_compat": "Provides better randomness in PHP 5.x" }, "autoload": { "psr-4": { "Libraries\\": "application/libraries" } } }  
      após instalar a NFePhp através do composer, o caminho da pasta NFePhp está assim:
      nome_do_meu_sistema
      |____ application
      |______vendor
      |________nfephp-org
      |__________sped-common
      |__________sped-da
      |__________sped-gtin
      |__________sped-nfe

      Como consigo trazer os comando/libraries da NFe para poder utilizar no projeto.
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Estou com uma dúvida e não estou conseguindo resolver.
       
      Tenho uma tabela onde o usuário lança a Entrada de Produtos <=== até aqui tudo bem.

      O problema que estou encontrando é: 
      - após lançar os itens e se por alguma necessidade precisar fazer devolução, gostaria de alterar o STATUS do lançamento do PRODUTO de 1 para 2, ou seja:
       
      lançou:
      101 - Caneta ------- 10 x 1.50 = 15,00 status = 1
      102 - Lápis --------- 10 x 1.50 = 15,00 status = 1
      103 - Borracha ---- 10 x 1.50 = 15,00 status = 1
      104 - Apontador - 10 x 1.50 = 15,00 status = 1
       
      Se precisar DEVOLVER os itens 102 e 103 o Status de 1 passa para 2, ou seja:
      101 - Caneta ------- 10 x 1.50 = 15,00 status = 1
      102 - Lápis --------- 10 x 1.50 = 15,00 status = 2
      103 - Borracha ---- 10 x 1.50 = 15,00 status = 2
      104 - Apontador - 10 x 1.50 = 15,00 status = 1
       
      Obs.: como consigo filtrar o CódigoProduto + NúmeroLançamento, para não ocorrer o erro de alterar todos.
       
      O problema que estou enfrentando, quando dou o Comando para Alterar, o Sistema Altera todos os produtos lançados que estiver na base de dados, ou seja, onde tiver 102 e 103, o sistema altera.
       
      o meu código:
      CONTROLLER
      /*Salva o Detalhe do Lançamento*/ protected function save_detalhe($prods,$qtde,$vlrunit,$vlrtotal,$notaLct,$numlcto,$codslct){ for ($i=0; $i < count($prods); $i++) { $data = array( 'cod_prod' => $prods[$i], 'qtd_prod' => $qtde[$i], 'vlr_unit' => $vlrunit[$i], 'vlr_total' => $vlrtotal[$i], 'status' => 2, 'devitens' => 2, 'n_nf' => $notaLct, 'lancamentos_idlcto'=> $numlcto, ); //Função para Salvar os Detalhes do lançamento $this->devolucao_model->save_detalhe($data); //Função para Atualizar a Quantidade de Produto no Estoque $this->update_produto($prods[$i],$qtde[$i],$vlrunit[$i],$vlrtotal[$i]); //Função para Alterar Devolução do Item $this->upd_itens($prods[$i],$notaLct[$i],$codslct[$i]); } } /*<=== até aqui tudo certo, como deve ser feito*/ /* * O Problema está aqui * para não ocorrer duplicidade de Lançamento, * o sistema altera o Status do 1º. lançamento */ protected function upd_itens($idprds,$notaLct,$codslct){ $data = array( 'devitens' => 2, ); $this->devolucao_model->update_itens($idprds,$data); }  
      MODEL:
      //Altera o Campo Devolução do Item Lançado //Altera todos os código de produto que encontrar public function update_itens($idprds,$data){ $this->db->where("cod_prod",$idprds); return $this->db->update("lctos_itens",$data); }  
      Grato,
       
      Cesar






       
       
       
       
       
       
    • Por violin101
      Caros amigos, saudações.
       
      Estou com uma dúvida e não consigo entender, fiz várias pesquisas e tentativas antes de recorrer aos amigos.

      Tenho uma CLASS e quando chamo dentro de um CONTROLLER o sistema acusa que não acha o caminho da CLASS.
      Como consigo fazer para o sistema localizar/chamar a CLASS dentro do Controller ?

      a classe está assim:
       
      <?php namespace Servicos; use NFePHP\NFe\Make; use NFePHP\NFe\Tools; error_reporting(E_ALL); ini_set('display_errors', 'On'); class NFeServicos{ public function __construct($config, $empresas){ //codes... } }  
      Controller:
       
      <?php defined('BASEPATH') OR exit('No direct script access allowed'); use NFePHP\Common\Certificate; use NFePHP\DA\NFe\Danfe; use Servicos\NFeServico; //chamo a class class NotaFiscal extends CI_Controller { public function gerarXml() { $id = $this->input->post('idLct'); $this->load->model('estoque/lancamentos_model', '', true); $venda = $this->lancamentos_model->getById($id); $nfe = new NFeServico(); //<o erro acontece aqui, não localiza. } }  
       
      Grato,
       
      Cesar
×

Informação importante

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