Jump to content
inhokinformatica

Executar arquivo sql no php

Recommended Posts

Bom dia.

 

Atualmente estou com dificuldades para executar um arquivo com instruções SQL diretamente no php. Tenho um planilha VBA que exporta as intruções e salva em um arquivo "xxxx.sql". São várias linhas, um exemplo a baixo.

INSERT INTO `fl_mes_05`(`id`, `matricula`, `dia`, `entrada_normal`, `saida_lanche`, `entrada_lanche`, `saida_normal`) VALUES ('1','913154','01/05/2019','00:00','00:00','00:00','00:00');
INSERT INTO `fl_mes_05`(`id`, `matricula`, `dia`, `entrada_normal`, `saida_lanche`, `entrada_lanche`, `saida_normal`) VALUES ('2','913154','02/05/2019','06:56','00:00','00:00','13:14');
INSERT INTO `fl_mes_05`(`id`, `matricula`, `dia`, `entrada_normal`, `saida_lanche`, `entrada_lanche`, `saida_normal`) VALUES ('3','913154','03/05/2019','07:12','11:15','11:35','13:11');

Bem...

 

Fiz o sistema para upload de arquivo

 

formulario.php

<form action="atualizar_frequencia.php" method="post" enctype="multipart/form-data">
					<input type="file" name="arquivo" />
					<input type="submit" value="Enviar"/>
				</form>

upload_sql.php

<?php 
error_reporting (E_ALL & ~ E_NOTICE & ~ E_DEPRECATED);

session_start(); // inicia sessão
include "../db.php"; // conecta no banco de dados **** PDO

$file = $_FILES["arquivo"]; // Arquivo recebido

$dir = "_frequencias/"; // Pasta para upload

// Movendo o arquivo da pasta temporaria para pasta de destino 
if (move_uploaded_file($file["tmp_name"], "$dir/".$file["name"])) { 
    echo "Upload Completo!<br>"; 
} 
else { 
    echo "Erro. Upload não realizado.";
  	exit;
}  

// Abre o Arquvio no Modo r (para leitura)
$arquivo = fopen ($dir."/".$file["name"], 'r');
	
// Lê o conteúdo do arquivo 
while(!feof($arquivo))
{
//Mostra uma linha do arquivo
$linha = trim(fgets($arquivo, 1024));

if($linha!=NULL){

				echo $linha.'<br />';

}}
echo "<br><br>".$dir.$file["name"]."<br><br>"; //mostras as linhas do arquivo sql

$sql = file_get_contents($dir.$file["name"]);
$qr = $PDO->exec($sql);

if($qr){
	echo "Sucesso! Dados salvos no BD";
  exit;
}else{
	echo "ERRO...";
  exit;
}
// Fecha arquivo aberto
fclose($arquivo);

?>

Até aí, tudo funcionou, consigo fazer o upload e ler o arquivo normalmente. Recentemente, consegui executar esse SQL no php para salvar os dados no banco mysql.

 

O que preciso agora é atualizar os dados no banco de dados. O sistema apresenta erro ao enviar o arquivo novamente

 

Share this post


Link to post
Share on other sites

Poderia fornecer mais informações?
 

Você diz que precisa atualizar os dados, mas você está fazendo upload de um arquivo com UPDATES ou INSERTS como esse que mostrou?


Se você estiver fazendo upload de arquivos somente com INSERTS para atualizar, vai dar erro por conta da coluna ID que provavelmente é primarykey e não pode repetir.


Se o arquivo for de UPDATES ou a coluna ID não for uma primarykey ou unique, informe qual erro que esta te retornando.

Share this post


Link to post
Share on other sites

Muito obrigado!

 

Já consegui resolver aqui. Precisei dormir para achar a solução kkkk

 

Vou deixar o código aqui. Vai que alguém precise usar algum dia.

 

formulario.php

<table border="1" width="30%" height="Auto" align="left">
		<form action="atualizar_frequencia.php" method="post" enctype="multipart/form-data">
		<tr>
			<td colspan="2" align="center">Selecione o Mês para atualização</td>
		</tr>
  
		<tr>
			<td align="center" bgcolor="#000000" width="20%"></td>
			<td align="center" bgcolor="#4682B4" width="80%">
					<select name="mes_escolhido">
						<option value="fl_mes_01">Janeiro 2019</option>
						<option value="fl_mes_02">Fevereiro 2019</option>
						<option value="fl_mes_03">Março 2019</option>
						<option value="fl_mes_04">Abril 2019</option>
						<option value="fl_mes_05">Maio 2019</option>
						<option value="fl_mes_06">Junho 2019</option>
						<option value="fl_mes_07">Julho 2019</option>
						<option value="fl_mes_08">Agosto 2019</option>
						<option value="fl_mes_09">Setembro 2019</option>
						<option value="fl_mes_10">Outubro 2019</option>
						<option value="fl_mes_11">Novembro 2019</option>
						<option value="fl_mes_12">Dezembro 2019</option>
					</select>
			</td>
		</tr>
			<tr>
			<td align="center" bgcolor="#000000" width="20%">Selecione o Arquivo</td>
			<td>
				
					<input type="file" name="arquivo" />
					<input type="submit" value="Enviar"/>
				
			</td>
		</tr>
		</form>
          </table> 

atualizar_frequencia.php

<?php 
//error_reporting (E_ALL & ~ E_NOTICE & ~ E_DEPRECATED);

session_start(); // inicia sessão
include "../db.php"; // conecta no banco de dados **** PDO

$file = $_FILES["arquivo"]; // Arquivo recebido
$mes  = $_POST["mes_escolhido"]; // Mês escolhido
$dir = "_frequencias/"; // Pasta para upload

echo "----- RESUMO -----<br>";
echo "Arquivo: ".$file["name"]."<br>";
echo "Mês Selecionado: ".$mes."<br>";
echo "Pasta: ".$dir."<br><br>";

// Movendo o arquivo da pasta temporaria para pasta de destino 
if (move_uploaded_file($file["tmp_name"], "$dir/".$file["name"])) { 
    echo "1º Etapa: Ok - Upload Completo!<br>"; 
} 
else { 
    echo "1º Etapa: NOK - Upload não realizado."; 
	exit;
}  

// Abre o Arquvio no Modo r (para leitura)
$arquivo = fopen ($dir."/".$file["name"], 'r');
	
// Lê o conteúdo do arquivo 

$i = 1;

while(!feof($arquivo))
{
	$i++;
//Mostra uma linha do arquivo
$linha = trim(fgets($arquivo, 1024));

if($linha!=NULL){
	
	if($i<="10")
	{
		//echo $i." - ".substr($linha, 13 , 9)."<br />";
		$mes_arquivo_sql = substr($linha, 13 , 9);
	}

}}
echo "Mês do Arquivo ".$mes_arquivo_sql."<br>";
echo "Arquivo Recebido: ".$dir.$file["name"]."<br>";

if($mes!=$mes_arquivo_sql){
	echo "<br><br><font color='red'><b>O arquivo enviado não corresponde ao mês selecionado</b> Verifique e tente novamente!</font><br><br>";
	echo "<a href='calculos_atrasos.php'>[VOLTAR]</a>";
	exit;
}else{
	echo "<font color='green'><b>Arquivo correspondente</b></font><br>";
}

//Apaga tabela para receber dados novos
$deleterecords = "TRUNCATE TABLE ".$mes;
$deletar = $PDO->exec($deleterecords);

//escreve na tabela
$sql = file_get_contents($dir.$file["name"]);
$qr = $PDO->exec($sql);


	if($qr){
			echo "2º Etapa: Ok - Salvo no Banco de Dados!!! <br><a href='calculos_atrasos.php'>[VOLTAR]</a>";
	}else{
			echo "2º Etapa: NOK - Erro ao salvar no Banco de Dados...";
	}
// Fecha arquivo aberto
fclose($arquivo);

?>

 

Resolvido!

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 lulabel
      Necessito criar um quiz usando matriz, session e placar mas não consigo de jeito nenhum, já tentei procurar videos ou algum lugar explicando como posso fazer isso, mas até agora nada, fico travado. Sou iniciante no php ainda então qualquer ajuda é uma luz bem vinda.
    • By Dark_Trap000
      Ola, eu tenho um problema ao salvar ips permitidos no MySQL
      segue o codigo de salvamento
      <?php session_start(); include "conexao.php"; if (empty($_SESSION['usuario'])) { header('Location: login.php'); exit(); } $ip = $_SESSION['ip']; echo $pegar_ip = $_SERVER["REMOTE_ADDR"]; if($ip == $pegar_ip) { echo "IP Autorizado!!!"; } else if($ip == 0) { $pegar_ip = $_SERVER["REMOTE_ADDR"]; echo "IP Não Registrado!!!"; $sql = "UPDATE usuario SET creditos = $salvar WHERE usuario_id = $id"; die(); } ?> ele chega á estar tudo certo, + o problema e salvar no mysql. qual o problema ?
    • By violin101
      Caros amigos, membros do grupo, saudações...
       
      Se postei minha dúvida na opção errada peço desculpa.
       
      Estou com uma pequena dúvida.
       
      Quando cadastro usuários na MySql utilizo PASSWORD_HASH para criptografar a Senha.
       
      Estou montando uma rotina, onde o usuário que esqueceu sua senha o sistema envia por e-mail a sua senha, mas me deparei com um pequeno problema.
       
      a senha criada pelo usuário, como por exemplo: 12345678 usando o PASSWORD_HASH fica desta forma: $2y$10$ukBckA5D2aSApHwv/GOKi.P/drP.jwAHOK/9SmWIgRxLUE.x9z.ZK
       
      Quando tento enviar a senha para o usuário vai conforme acima, preciso enviar apenas 12345678. Como consigo descriptografar o PASSWORD_HASH ?
       
      Grato,
       
      Cesar
    • By elisandrodceza
      Alguma ideia para pesquisar os $id recebidos por get em um arquivo diferente ? como se percebe no código funcional a baixo, os $id estão duplicados para funções diferente. Quero adicionar eles em outro arquivo para uma melhor organização com as variáveis $id e $client,  mas de uma maneira que possa pesquisar tanto qual é a $id e o $client para ser informado por email quando o client ler o qrcode, quanto se a $id está na lista para ser redirecionado.
       
       
      ARQUIVO auth_code.php
       
      <?php
          $id = $_GET['id'];
          $ip = $_SERVER['REMOTE_ADDR'];
          $browser = $_SERVER['HTTP_USER_AGENT'];
          $to = "suporte@eatech.inf.br";
          $success = false;

              if ($id == '2623F52846F8A03DA4ADFA9392486807') $client = "Card Contato";
              if ($id == '2BDBDDA17456A1060E156BE7A487FC') $client = "Client 1";
              if ($id == 'E7EA229948A4997C2F72219D6A2764') $client = "Client 2";
              if ($id == '07118879907903166B2C3BE7408EFD') $client = "Client 3";
              if ($id == 'FED09C7CC40ACD77A0BDEA57E894A3') $client = "Client 4";
              if ($id == 'C042D3187B52E87D6E6196567101EF') $client = "Client 5";
              if ($id == '7DCD0215BEC8AF587AD886E407A485') $client = "Client 6";
       
          $messagem = "Cliente: $client<br><br>ID: $id<br><br>IP: $ip<br><br>Browser: $browser"; 
          $assunto = "qrCode digitalizado";
          $headers = "MIME-Version: 1.0\n";
          $headers .= "Content-type: text/html; charset=iso-8859-1\n";
          $headers .= "From: $client\n";
          
          $success = mail($to, $assunto, $messagem, $headers);
          
          if ($id == '2623F52846F8A03DA4ADFA9392486807')
              { header('Location: download/contato.vcf');}
       
          else
              if (

              $id == '2BDBDDA17456A1060E156BE7A487FC' # Client 1
              or $id == 'E7EA229948A4997C2F72219D6A2764' # Client 2
              or $id == '07118879907903166B2C3BE7408EFD' # Client 3
              or $id == 'FED09C7CC40ACD77A0BDEA57E894A3' # Client 4
              or $id == 'C042D3187B52E87D6E6196567101EF' # Client 5
              or $id == '7DCD0215BEC8AF587AD886E407A485' # Client 6
              )
              { header('Location: download/index.php?id=' . $id. '.pdf');}
       
          else
              { echo "<script>alert('Este qrCode ainda não está cadastrado no sistema, tente novamente mais tarde!');history.go(-1) </script>";}
      ?>
    • By rfael023
      Bom dia, Pessoal.

      Sou iniciante em PHP e estou trabalhando na integração de uma API. Estou tendo um pouco de dificuldade em índices de um array, segue abaixo o trecho do código:


       
      1 2 3 4 5 6 7 foreach ($Lista as $SMS) {           foreach ($SMS as $key => $value) {                   echo "{$key} : {$value}\n";         } }

      O resultado é o seguinte:

      telefone : 5519333333333
      id : 921

      telefone : 5519344444444
      id : 922

      telefone : 5519555555555
      id : 923

      Ou seja, eu tenho vários arrays com 2 posições dentro de um único array.

      Eu preciso jogar o ID e o Telefone em variáveis, porém ele não está entendendo meu índice:
       
      1 2 3 4 $sms->setTo($SMS['telefone']); echo $sms->getTo(); $sms->setId($SMS['id']); echo $sms->getId();

      Resultado:

      5,52E+12
      Notice: Undefined index: id in C:\xampp1\htdocs\SMSM\exemplos\envio_multiplo_teste.php on line 42
      5,52E+12
      Notice: Undefined index: id in C:\xampp1\htdocs\SMSM\exemplos\envio_multiplo_teste.php on line 42
      5,51198E+12
      Notice: Undefined index: id in C:\xampp1\htdocs\SMSM\exemplos\envio_multiplo_teste.php on line 42
      5,51198E+12
      Notice: Undefined index: id in C:\xampp1\htdocs\SMSM\exemplos\envio_multiplo_teste.php on line 42
      5,53176E+11
      Notice: Undefined index: id in C:\xampp1\htdocs\SMSM\exemplos\envio_multiplo_teste.php on line 42
      5,53176E+11
      Notice: Undefined index: id in C:\xampp1\htdocs\SMSM\exemplos\envio_multiplo_teste.php on line 42

      Alguém consegue me ajudar?

      Agradeço, desde já!
×

Important Information

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