Jump to content
emmanuelsiqueira30

Querys para 3 tabelas não executam

Recommended Posts

Pessoal o problema é o seguinte estou tentando inserir a informação de matrícula de alunos utilizando 3 tabelas.

1 - matricula

2 - contasreceber

3 - parcelareceber

 

Mas as querys da tabela contasreceber e parcelareceber não executam e também o outro problema é que a data das parcelas ficam dando o ano de 2020 em vez de 2019.

Agradeço toda ajuda possível.

cadMatriculaView

<!DOCTYPE html>
<html>
<title>Matrícula do aluno</title>
<head>
	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script>
</head>
<body>
<?php include 'menuView.php'; ?></br></br>

<?php ini_set( 'default_charset', 'UTF-8' );
ini_set( 'mbstring.http_output', 'UTF-8' );
ini_set( 'mbstring.internal_encoding', 'UTF-8' );
header("Content-Type: text/html; charset=UTF-8",true);  
?>

<font face="verdana" size="4">
	<form action="../Model/cadMatriculaModel.php" method="POST">
		
		<fieldset>
			<legend>CONSULTA DE ALUNO</legend>
			<label for="proprietario_id_prop">Digite o CPF do aluno: </label>
				<input type="text" class="form-control" name="textbox" id="textbox" placeholder="Digite CPF do aluno"></br>
					ALUNO: <select class="form-control" name="id_aluno" id="select" style="width: 400px">
						<?php
							include ("../Controller/conexao.php");
							$query = "SELECT * FROM aluno";
							$consulta = mysqli_query($con,$query); 
							while ($dados = mysqli_fetch_assoc($consulta)) { ?>
								<option value="<?php echo $dados['idaluno']; ?>"><?php echo $dados['cpfaluno'] . " - " . $dados['nomealuno']; ?></option> <?php 
							}
						?>
					</select></br>
		</fieldset>
		
		<fieldset>
			<legend>ESCOLHA DO CURSO</legend>
					CURSO: <select class="form-control" name="id_curso" id="select">
						<?php
							include ("../Controller/conexao.php");
							$query = "SELECT * FROM curso";
							$consulta = mysqli_query($con,$query); 
							while ($dados = mysqli_fetch_assoc($consulta)) { ?>
								<option value="<?php echo $dados['id_curso']; ?>"><?php echo $dados['nome_curso'] . " - " . $dados['turno_curso']; ?></option> <?php 
							}
						?>
					</select></br>
		</fieldset>
		
		TIPO DE PAGAMENTO: <select name="tipo_pag_matricula">
							<option value="1">A PRAZO</option>
					   </select></br>
		
		DIA DO VENCIMENTO: <input type="number" name="dt_venc_pag_matricula" maxlength="2">
		NÚMERO DE PARCELAS: <input type="number" name="n_parc_matricula" maxlength="2">
		DESCONTO: <input type="number" name="desc_matricula" style="width: 50px" value="0">% </br>
		
		<span style="color: red; font-size: 8pt">* Campos obrigatórios.</span></br>
		<button type="submit" name="btninserir">INSERIR MATRÍCULA</button>
	</form>
</font>

<script>
jQuery.fn.filterByText = function(textbox, selectSingleMatch) {
        return this.each(function() {
            var select = this;
            var options = [];
            $(select).find('option').each(function() {
                options.push({value: $(this).val(), text: $(this).text()});
            });
            $(select).data('options', options);
            $(textbox).bind('change keyup', function() {
                var options = $(select).empty().data('options');
                var search = $(this).val().trim();
                var regex = new RegExp(search,"gi");
              
                $.each(options, function(i) {
                    var option = options[i];
                    if(option.text.match(regex) !== null) {
                        $(select).append(
                           $('<option>').text(option.text).val(option.value)
                        );
                    }
                });
                if (selectSingleMatch === true && $(select).children().length === 1) {
                    $(select).children().get(0).selected = true;
                }
            });            
        });
    };

    $(function() {
        $('#select').filterByText($('#textbox'), false);
      $("select option").click(function(){
        alert(1);
      });
    });
</script>



</body>
</html>

cadMatriculaModel

 

<?php
	
	include("../Controller/conexao.php");
	include("../Controller/util.php");
	
	header('Content-Type: text/html; charset=utf-8');
	
	$id_aluno = $_POST['id_aluno'];
	$id_curso = $_POST['id_curso'];
	$data_matricula = date("Y-m-d");
	$codunico_matricula = bin2hex(random_bytes(8));
	$tipo_pag_matricula = $_POST['tipo_pag_matricula'];
	$dt_venc_pag_matricula = $_POST['dt_venc_pag_matricula'];
	$desc_matricula = $_POST['desc_matricula'];
	$n_parc_matricula = $_POST['n_parc_matricula'];
	
	$sql_valor_curso = "SELECT * FROM curso WHERE id_curso = $id_curso";
	$result_valor_curso = mysqli_query($con,$sql_valor_curso);
	$row_valor_curso = mysqli_fetch_assoc($result_valor_curso);
	$valor_curso = $row_valor_curso['valor_curso'];
	
	$valor_final = $valor_curso - $desc_matricula;
	
	$dt_curso_ini  = $row_valor_curso['data_inicio_curso'];
	$dt_curso_fim  = $row_valor_curso['data_fim_curso'];
 	$dif = strtotime($dt_curso_fim) - strtotime($dt_curso_ini);
 	$periodo_curso_meses = floor($dif / (60 * 60 * 24 * 30));
 	
	$valor_parc = $valor_final / $periodo_curso_meses;
	
	$sqlmatriculaexistente = "SELECT * FROM matricula WHERE id_curso = $id_curso AND id_aluno = $id_aluno AND codunico_matricula = $codunico_matricula";
	$resultmatriculaexistente = mysqli_query($con,$sqlmatriculaexistente);
	
	if (resultmatriculaexistente > 0) {
		echo "<script>alert('Matrícula já existente.'); location='../View/cadMatriculaView.php';</script>";	
	}
	else {
		
		$sqlmatricula = "INSERT INTO matricula (id_aluno,id_curso,data_matricula,codunico_matricula,tipo_pag_matricula,dt_venc_pag_matricula,desc_matricula,n_parc_matricula) 
		VALUES ('$id_aluno','$id_curso','$data_matricula','$codunico_matricula','$tipo_pag_matricula','$dt_venc_pag_matricula','$desc_matricula','$n_parc_matricula')";
		$resultmatricula = mysqli_query($con,$sqlmatricula);
		$ultimamatricula = mysqli_insert_id($con);
		echo $ultimamatricula;
				
		$sqlcr = "INSERT INTO contasreceber (id_matricula_cr,valor_total_cr,desc_cr,valor_final_cr,n_parc_cr) 
		VALUES ('$ultimamatricula','$valor_curso','$desc_matricula','$valor_final','$n_parc_matricula')";
		$resultcr = mysqli_query($con,$sqlcr);
		$ultimacr = mysqli_insert_id($con);
		echo $ultimacr;
				
		$desc_pr = 0;
		$valor_final_pr = $valor_parc;
		
		for($x = 0; $x < $n_parc_matricula; $x++){
			
			$dia = date("d");
			$mes = date("m");
			$ano = date("Y");
			
			$dt_venc_pr = date("Y/m/d",strtotime("+".$x." month",mktime(0, 0, 0,$dia,$mes,$ano)));
			echo $dt_venc_pr;
 			
			$sqlpr = "INSERT INTO parcelareceber (id_cr_pr,valor_parc_pr,desc_pr,valor_final_pr,dt_venc_pr,dt_pg_pr,valor_pg,valor_pag_pr) 
			VALUES ('$ultimamatricula','$valor_parc','$desc_pr','$valor_final_pr','$dt_venc_pr','?','?')";
			$resultpr = mysqli_query($con,$sqlpr);
		
		}		
		
	}
	
	if ($resultmatricula && resultpr) {
			//echo "<script>alert('Cadastro realizado com sucesso.'); location='../View/cadMatriculaView.php';</script>";
	} else {
			//echo "<script>alert('Erro ao cadastrar.'); location='../View/cadMatriculaView.php';</script>";
			echo mysqli_error($con);
	}
		
	$con->close();		
	
?>

 

Share this post


Link to post
Share on other sites

Oi boa noite,

 

Tente adicionar o código no arquivo para definir o timezone correto:

date_default_timezone_set(America/Sao_Paulo);

 

As vezes o seu servidor está com um date time diferente do nosso, percebi que você está pegando a data atual do servidor na variável:

$data_matricula = date("Y-m-d");

Pois no trecho que você mostra, teoricamente era para capturar os dados do dia, mês e ano atual (quando eu faço esse post o ano 19):

$dia = date("d");
$mes = date("m");
$ano = date("Y");

 

Share this post


Link to post
Share on other sites

OK, mas o grande problema do código é não executar o for para salvar as informações das parcelas.

Em 22/06/2019 at 00:49, André Severino disse:

Oi boa noite,

 

Tente adicionar o código no arquivo para definir o timezone correto:


date_default_timezone_set(America/Sao_Paulo);

 

As vezes o seu servidor está com um date time diferente do nosso, percebi que você está pegando a data atual do servidor na variável:


$data_matricula = date("Y-m-d");

 

Pois no trecho que você mostra, teoricamente era para capturar os dados do dia, mês e ano atual (quando eu faço esse post o ano 19):


$dia = date("d");
$mes = date("m");
$ano = date("Y");

OK, mas o grande problema do código é não executar o for para salvar as informações das parcelas.

 

 

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 tekton
      Preciso fazer um CRUD de teste para tentar uma vaga em uma empresa. Nesse teste, tive que criar os campos Nome, Email, Telefone e Endereço, e deveria ser possível inserir mais de um endereço por nome nesse CRUD. Acho que não da pra simplesmente criar outro campo para inserir outro endereço. Acho que o objetivo do teste é que eu crie relacionamento de tabelas, mas não faço ideia de como começar. Estou fazendo o CRUD com PHP e já tenho tudo pronto, adicionar, editar e excluir. Já está tudo funcionando. Só falta agora essa opção pra poder colocar mais de um endereço por nome. Vou colocar o código da classe e do BD. Se precisarem de mais algum é só avisar. Agradeço de antemão pela ajuda.
       
      -- phpMyAdmin SQL Dump -- version 4.8.3 -- https://www.phpmyadmin.net/ -- -- Host: localhost:3306 -- Generation Time: Nov 16, 2019 at 11:19 PM -- Server version: 5.7.24 -- PHP Version: 7.3.7 SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; SET AUTOCOMMIT = 0; START TRANSACTION; SET time_zone = "+00:00"; /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8mb4 */; -- -- Database: `crudoo` -- -- -------------------------------------------------------- -- -- Table structure for table `contatos` -- CREATE TABLE `contatos` ( `id` int(11) UNSIGNED NOT NULL, `nome` varchar(100) DEFAULT NULL, `email` varchar(100) NOT NULL DEFAULT '', `telefone` varchar(20) NOT NULL, `endereco` varchar(100) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- -- Dumping data for table `contatos` -- INSERT INTO `contatos` (`id`, `nome`, `email`, `telefone`, `endereco`) VALUES (2, 'test2e', 'teste2@teste.com', '316497', 'rua a'), (4, 'wanderson', 'sonwander@yahoo.com.br', '985930559', 'rua brasil'), (6, 'andrezinho', 'andre@site.com', '2222222222', 'rua j'); -- -- Indexes for dumped tables -- -- -- Indexes for table `contatos` -- ALTER TABLE `contatos` ADD PRIMARY KEY (`id`); -- -- AUTO_INCREMENT for dumped tables -- -- -- AUTO_INCREMENT for table `contatos` -- ALTER TABLE `contatos` MODIFY `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=7; COMMIT; /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */; <?php class Contato { private $pdo; public function __construct() { $this->pdo = new PDO("mysql:dbname=crudoo;host=localhost", "root", "root"); } public function adicionar($email, $nome, $telefone, $endereco) { if($this->existeEmail($email) == false) { $sql = "INSERT INTO contatos (nome, email, telefone, endereco) VALUES (:nome, :email, :telefone, :endereco)"; $sql = $this->pdo->prepare($sql); $sql->bindValue(':nome', $nome); $sql->bindValue(':email', $email); $sql->bindValue(':telefone', $telefone); $sql->bindValue(':endereco', $endereco); $sql->execute(); return true; } else { return false; } } public function getInfo($id) { $sql = "SELECT * FROM contatos WHERE id = :id"; $sql = $this->pdo->prepare($sql); $sql->bindValue(':id', $id); $sql->execute(); if($sql->rowCount() > 0) { return $sql->fetch(); } else { return array(); } } public function getAll() { $sql = "SELECT * FROM contatos"; $sql = $this->pdo->query($sql); if($sql->rowCount() > 0) { return $sql->fetchAll(); } else { return array(); } } public function editar($nome, $email, $telefone, $endereco, $id) { if($this->existeEmail($email) == false){ $sql = "UPDATE contatos SET nome = :nome, email = :email, telefone = :telefone, endereco = :endereco WHERE id = :id"; $sql = $this->pdo->prepare($sql); $sql->bindValue(':nome', $nome); $sql->bindValue(':email', $email); $sql->bindValue(':telefone', $telefone); $sql->bindValue(':endereco', $endereco); $sql->bindValue(':id', $id); $sql->execute(); return true; } else { return false; } } public function excluir($id) { $sql = "DELETE FROM contatos WHERE id = :id"; $sql = $this->pdo->prepare($sql); $sql->bindValue(':id', $id); $sql->execute(); } private function existeEmail($email) { $sql = "SELECT * FROM contatos WHERE email = :email"; $sql = $this->pdo->prepare($sql); $sql->bindValue(':email', $email); $sql->execute(); if($sql->rowCount() > 0) { return true; } else { return false; } } }  
    • By ivanjrx
      estou tentando montar um projeto em php+html pra um projeto para faculdade em Arduíno, infelizmente entendo quase nada de php.
      o problema:
      <html> <head> <title>LED ON/OFF</title> </head> <body> <p align="center"> <font size="8"> <b><a href="led.php?state=1">ON</a></b> / <b><a href="led.php?state=0">OFF</a></b></font> </p> </body> </html> <html> <head> <title>Arduino Controlled Based PHP</title> </head> <body> <?php echo "<p>Control Page</p><p>"; $port = fopen("COM7", "w+"); sleep(0); ?> <br> <form action="index.php" method="POST"> <input type="hidden" name="turn" value="on" /> <input type="Submit" value="on"> </form> <form action="index.php" method="POST"> <input type="hidden" name="turn" value="off" /> <input type="Submit" value="off"> </form> <?php if ($_POST['turn']=="on") { echo "Turned on"; fwrite($port, "n"); } if ($_POST['turn']=="off") { echo "Turned off"; fwrite($port, "f"); } fclose($port); ?> </body> </html>  
    • By Ak_Ray
      Olá, estou com problemas para fazer conexão com a minha conta adm e acessar a página que desejo. Testei o código em um servidor local criado pelo xampp e funciona normalmente, mas foi só fazer um upload para a web e parou de funcionar. Erro: 
       
      Warning: session_start(): Cannot start session when headers already sent in [...] on line28
       
      Código (página de acesso) -------------------------------------------------------------------------------------
      <?php
      require_once '../../Controller/adm-login/checarexistencia.php';
      $u = new Usuario;?>
      <html lang="pt-br">
      <head>
      <link rel="shortcut icon" href="../../Model/img/cadeado.png">
      <meta charset="utf-8">
      <link rel="stylesheet" href="../../Model/estilo/estilodado.css" type="text/css" media="screen">
      <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.8.2/css/all.css"
              integrity="sha384-oS3vJWv+0UjzBfQzYUhtDYW+Pj2yciDJxpsK1OYPAYjqT085Qq/1cq5FLXAZQ7Ay" crossorigin="anonymous">
      <title> Dados Restritos </title>
      </head> <body>
        <div class="container">
          <div class="content first-content">           
                 <div class="second-column">
                  <p class="title1"> Usuário </p>
                  <form class="form" method="POST">
                    <label for="" class="label-input">
                      <i class="far fa-user"></i>
                    <input class="form-input" type="text" name="nome" required  placeholder="Usuario" maxlength="50"></label> 
                    <label for="" class="label-input">
                      <i class="fas fa-key"></i>
                    <input class="form-input" type="password" name="senha" required placeholder="Senha" maxlength="45"></label> 
                    <input class="btn" type="submit" value="Login">
      <?php
      if(isset($_POST['nome']))
       {
        $nome = addslashes($_POST['nome']);
        $senha = addslashes($_POST['senha']);
        //verificar se não está vázio
        if(!empty($nome) && !empty($senha))
        {
           //obs: deixei sem as informações de conexão com o banco, mas está conectando corretamente
           $u->conectar("#,"#","#,"#");
            if($u->msgErro == "")//se esta tudo ok
               {
            
               if($u->logar($nome,$senha)){
               header('Location: ../../View/dadosfiltrados.php');
          }
          else{
            ?>
              <div class="msg-erro">
              Usuario ou senha estão incorretos!
              </div>
            <?php
            }
           }
           else{
            ?> 
              <div class="msg-erro">
              <?php echo "Erro ".$u->msgERRO; ?>  
              </div>  
            <?php
           }
          }
          else{
            ?>
            <div class="msg-erro">
             Preencha todos os campos!
              </div>
          <?php
          }
      }
       ?></form></div></div>
      <a class="home animacao" href="../View/index.php"><img src="../../Model/img/home.png"></a>
      </body>
      </html>
      -------------------------------------------------------------------------------------------------------------------
       
      Código (checar existência de usuário) -----------------------------------------------------------------------
      <?php
      $mysqli = new PDO("mysql:dbname=#;host=#","#","#"); 
       class Usuario
      {
          private $pdo;
          public $msgErro = "";
          public function conectar($nome, $host, $usuario, $senha)
          {
              global $pdo;
              global $msgErro;
              try {
              $pdo = new PDO("mysql:dbname=".$nome.";host=".$host,$usuario,$senha);    
              } catch (PDOException $e) {
                  $msgErro = $e->getMessage(); 
              }
              
          }  
          public function logar($nome, $senha)
          {
              global $pdo;
             
              $sql = $pdo->prepare("SELECT * from admin where nome = :n and senha = :s");
              $sql->bindValue(":n",$nome);
              $sql->bindValue(":s",md5($senha));
              $sql->execute();
              if($sql->rowCount() > 0)
              {
                 $dado = $sql->fetch();
                 session_start();
                 $_SESSION['idadmin'] = $dado['idadmin'];
                 return true; 
              }
              else
              {
                 return false;
              }
          }
      }?>
    • By eduh.castro19
      Olá,boa noite a todos.
      Estou com um problema e já não sei como arrumar, toda vez que uso o a função =
       
      $json = file_get_contents('http://localhost/arquivo1.php'); $obj = json_decode($json); echo $obj->nome;  
      Ele me retorna um erro = ( Trying to get property 'name' of non-object in )
      Tenho 3 arquivos (Conexão.php,Arquivo1.php,Arquivo2.php)
      Eles estão assim:
       
      Arquivo1 =
      require('conexão.php'); while ($row = $usuarios->fetch(PDO::FETCH_ASSOC)) {      $nomex = $row['nome'];      $datax = $row['data'];       $encoda= array('nome' => $nomex, 'data' => $datax );     echo json_encode($encoda);} Arquivo2 =
      $json = file_get_contents('http://localhost/arquivo1.php'); $obj = json_decode($json); echo $obj->nome; echo json_last_error_msg(); O erro acontece no Arquivo2
      Já tentei por HTTP HEADER JSON Mas não adiantou,não sei mais o que fazer,se alguem puder ajudar. Agradecerei demais! Boa noite a todos.
       
       
       
    • By Diego_Sousa
      me ajudem pf, para o tcc
       
      me ajudem fiz o meu codigo mas ele fica colocando como "No database selected", sendo que tenho o meu MYSQL todo certo e funcionando (tanto pelo PHP MY ADMIN, como no normal) 
      segue o codigo:
       

       
      <?php class Banco { private $host = "localhost"; private $banco = "bancoTCC"; private $user = "root"; private $senha = ""; public $con; function conecta(){ $this->con = @mysqli_connect("$host", "$user", "$senha"); // Conecta ao Banco de Dados if(!$this->con){ // Caso ocorra um erro, exibe uma mensagem com o erro die ("Problemas com a conexão" . @mysqli_connect_error($this->con)); } } // método responsável para fechar a conexão function fechar(){ mysqli_close($this->con); return; } // método para executar o SELECT (consultar.php, verexclusao.php, veralteracao.php) function exersec($string,$texto){ //SQL String $resultado = @mysqli_query($this->con, $string); if (!$resultado) { echo '<input type="button" onclick="window.location='."'Index.php'".';" value="Voltar"><br /><br />'; die("Query Inválida:". @mysqli_error($this->con)); } else { echo "<b>$texto </b> - Realizada com Sucesso"; } $this->fechar(); // chama o método que fecha a conexão return; } function exerprin($string,$caminho){ //SQL Query // executando instrução SQL $resultado = @mysqli_query($this->con, $string); if (!$resultado) { echo '<input type="button" onclick="window.location='."'Index.php'".';" value="Voltar"><br /><br />'; die('<b>Query Inválida:</b>' . @mysqli_error($this->con)); } else { $num = @mysqli_num_rows($resultado); if ($num==0){ echo "<b>Código: </b>não localizado !!!!<br /><br />"; echo '<input type="button" onclick="window.location='."'$caminho'".';" value="Voltar"><br /><br />'; exit; }else{ $dados=mysqli_fetch_array($resultado); } $this->fechar(); // chama o método que fecha a conexão return $dados; } // método para executar o INSERT, UPDATE e DELETE (incluir.php, alterar.php, excluir.php) } } ?>  
       
       
       
       
       
       
       
       
       
      e da pagina na qual uso para inserir no banco
       
       
       
       
       
      <html> <head> <title> Dados salvos</title> </head> <body> <h3> Efetiva a inclusao dos dados </h3> <?php include('Geral.php'); //criando o objeto mysql e conectando ao banco de dados $mysql = new Banco(); $mysql->conecta(); // recuperando os dados de inclusao.php $Login = $_POST['Login']; $Senha = $_POST['Senha']; $Nome = $_POST['Nome']; $Nasc = $_POST['Nasc']; $E_mail = $_POST['E_mail']; $Sexo = $_POST['Sexo']; $CPF = $_POST['CPF']; // criando a linha de INSERT $sqlinsert = "insert into pessoa_fisica (Senha, Login, Nome, Nasc, E_mail, Sexo, CPF) values ('$Senha', '$Login', '$Nome', '$Nasc', '$E_mail', '$Sexo', '$CPF')"; // executando instrução SQL através do método sqlstring() que esta em conexao.php $resultado = $mysql->exersec($sqlinsert,"pessoa_fisica"); ?> <br /><br /> <form name="produto" action="ConsultaT1.php" method="post"> <b>Consulta de Dados</b> <input type="submit" value="PROXIMO"> </form> <form name="produto" action="DCuriculos.php" method="post"> <b>Inserir Curriculo</b> <input type="submit" value="PROXIMO"> </form> </body> </html>  
×

Important Information

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