Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

allencar.limma

Não consigo gravar no Banco de Dados

Recommended Posts

Tento incluir as informações de um formulário no banco de dados e não consigo. conforme código abaixo.

<?

/*Incluir as informações no formulario */

include "config.php";

$nome = trim($_POST['nome']);
$masp = trim($_POST['masp']);
$cpf = trim($_POST['cpf']);
$telefone = trim($_POST['telefone']);
$email = trim($_POST['email']);
$endereco = trim($_POST['endereco']);
$data_nascimento = trim($_POST['data_nascimento']);
$unidade_lotacao = trim($_POST['unidade_lotacao']);

/* Vamos checar algum erro nos campos */

if ((!$nome) || (!$masp) || (!$cpf) || (!$telefone) || (!$email) || (!$endereco) || (!$data_nascimento) || (!$unidade_lotacao)){

echo "ERRO: <br /><br />";
    

if (!$nome){

echo "Nome Completo é requerido.<br />";

}

if (!$masp){

echo "Masp é requerido.<br />";
    
}
    
if (!$cpf){
    
echo "CPF é requerido.<br /)>";

}
    
if (!$telefone){
    
echo "Telefone é requerido.<br />";

}
if (!$email){
    
echo "Email é requerido.<br />";
}
    
if (!$endereco){
    
echo "Endereço é requerido.<br />";
        
}

if (!$data_nascimento){

echo "Data de Nascimento é requerido.<br />";

}
    
if (!$unidade_lotacao){
    
echo "Unidade de Lotação é requerido.<br>";
    
}    

echo "Preencha os campos abaixo: <br />";

include "formulario_cadastro.php";

}else
    
{
    

/* Vamos checar se o nome de Usuário escolhido e/ou Email já existem no banco de dados */

$sql_email_check = mysql_query(

"SELECT COUNT(usuario_id) FROM usuarios WHERE email='{$email}'"

);

$sql_masp_check = mysql_query(

"SELECT COUNT(usuario_id) FROM usuarios WHERE masp='{$masp}'"

);
    
$sql_cpf_check = mysql_query(

"SELECT COUNT(usuario_id) FROM usuarios WHERE cpf='{$cpf}'"

);    
    
    

$eReg = mysql_fetch_array($sql_email_check);
$uReg = mysql_fetch_array($sql_masp_check);
$uReg = mysql_fetch_array($sql_cpf_check);

$email_check = $eReg[0];
$masp_check = $uReg[0];
$cpf_check = $uReg[0];    

if (($email_check > 0) || ($masp_check > 0) || ($cpf_check > 0)){

echo "<strong>ERRO</strong>: <br /><br />";

if ($email_check > 0){

echo "Este email já está sendo utilizado.<br /><br />";

unset($email);

}

if ($masp_check > 0){

echo "Este Masp já está sendo
utilizado.<br /><br />";

unset($masp);

}
if ($cpf_check > 0){

echo "Este CPF já está sendo
utilizado.<br /><br />";

unset($cpf);    
    
}

include "formulario_cadastro.php";

}else{

/* Se passarmos por esta verificação ilesos é hora de
finalmente cadastrar os dados. Vamos utilizar uma função para gerar a senha de
forma randômica*/

function makeRandomPassword(){

$salt = "abchefghjkmnpqrstuvwxyz0123456789";
srand((double)microtime()*1000000);
$i = 0;

while ($i <= 7){

$num = rand() % 33;
$tmp = substr($salt, $num, 1);
$pass = $pass . $tmp;
$i++;

}

return $pass;

}

$senha_randomica = makeRandomPassword();
$senha = md5($senha_randomica);

// Inserindo os dados no banco de dados

//$cpf = htmlspecialchars($cpf); ***RETIRADO PELO FATO DE NÃO ESTA SENDO USADO

$sql = mysql_query(

"INSERT INTO usuarios

(none, masp, cpf, telefone, email, endereco, data_nascimento, unidade_lotacao)

VALUES
('$nome', '$masp', '$cpf', '$telefone', '$email', '$endereco', '$data_nascimento', '$unidade_lotacao', now())")

    or die( mysql_error()
           );
    
    if (!$sql){
    
    echo "Ocorreu um erro ao criar sua conta, entre em contato.";
        
}else{
        
    $usuario_id = mysql_insert_id();
        
    

// Enviar um email ao usuário para confirmação e ativar o cadastro!

$headers = "MIME-Version: 1.0\n";
$headers .= "Content-type: text/html; charset=iso-8859-1\n";
$headers .= "From: RCI - <rci@rcionline.com.br>";

$subject = "Confirmação de cadastro - www.rcionline.com.br";
$mensagem = "Prezado {$nome} {$masp},<br />
Obrigado pelo seu cadastro em nosso site, <a href='http://www.rcionline.com.br'>
http://www.rcionline.com.br</a>!<br /> <br />

Para confirmar seu cadastro e ativar sua conta em nosso site, podendo acessar à
áreas exclusivas, por favor clique no link abaixo ou copie e cole na barra de
endereço do seu navegador.<br /> <br />

<a href='http://www.rcionline.com.br/ativar.php?id={$usuario_id}&code={$senha}'>

http://www.rcionline.com.br/ativar.php?id={$usuario_id}&code={$senha}

</a>

<br /> <br />
Após a ativação de sua conta, você poderá ter acesso ao conteúdo exclusivo
efetuado o login com os seguintes dados abaixo:<br > <br />

<strong>Usuario</strong>: {$usuario_id}<br />
<strong>Senha</strong>: {$senha_randomica}<br /> <br />

Obrigado!<br /> <br />

Webmaster<br /> <br /> <br />
Esta é uma mensagem automática, por favor não responda!";

mail($email, $subject, $mensagem, $headers);

echo "Foi enviado para seu email - ( ".$email." ) um pedido de
confirmação de cadastro, por favor verifique e sigas as instruções!";

}

}

    
}

?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Creio que o SQL do INSERT deveria ser assim:

 

ANTERIOR

		$sql = mysql_query (
			"INSERT INTO usuarios (
				none, 
				masp, 
				cpf, 
				telefone, 
				email, 
				endereco, 
				data_nascimento, 
				unidade_lotacao
			) VALUES (
				'$nome', 
				'$masp', 
				'$cpf', 
				'$telefone', 
				'$email', 
				'$endereco', 
				'$data_nascimento', 
				'$unidade_lotacao', 
				now()
			)"
		) or die ( mysql_error () );

 

"NOVO"


		$sql = mysql_query (
			"INSERT INTO usuarios (
				nome, 
				masp, 
				cpf, 
				telefone, 
				email, 
				endereco, 
				data_nascimento, 
				unidade_lotacao
			) VALUES (
				'$nome', 
				'$masp', 
				'$cpf', 
				'$telefone', 
				'$email', 
				'$endereco', 
				'$data_nascimento', 
				'$unidade_lotacao'
			)"
		) or die ( mysql_error () );

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
20 horas atrás, ShadowDLL disse:

Creio que o SQL do INSERT deveria ser assim:

ANTERIOR


		$sql = mysql_query (
			"INSERT INTO usuarios (
				none, 
				masp, 
				cpf, 
				telefone, 
				email, 
				endereco, 
				data_nascimento, 
				unidade_lotacao
			) VALUES (
				'$nome', 
				'$masp', 
				'$cpf', 
				'$telefone', 
				'$email', 
				'$endereco', 
				'$data_nascimento', 
				'$unidade_lotacao', 
				now()
			)"
		) or die ( mysql_error () );

 

 

"NOVO"



		$sql = mysql_query (
			"INSERT INTO usuarios (
				nome, 
				masp, 
				cpf, 
				telefone, 
				email, 
				endereco, 
				data_nascimento, 
				unidade_lotacao
			) VALUES (
				'$nome', 
				'$masp', 
				'$cpf', 
				'$telefone', 
				'$email', 
				'$endereco', 
				'$data_nascimento', 
				'$unidade_lotacao'
			)"
		) or die ( mysql_error () );

 

Bom dia! feito a correção como foi informando, porém  começou a gerar uma erro na linha 80:

/* Vamos checar se o nome de Usuário escolhido e/ou Email já existem no banco de dados */

$sql_email_check = mysql_query(

"SELECT COUNT(usuario_id) FROM usuarios WHERE email='{$email}'"

onde linha 80 é: $sql_email_check = mysql_query  (

 

erro apresentado :

PHP Fatal error:  Uncaught Error: Call to undefined function mysql_query() in /home3/rcionl85/public_html/cadastrar.php:80
Stack trace:
#0 {main}
  thrown in /home3/rcionl85/public_html/cadastrar.php on line 80

Desculpe-me pelas dúvidas, sou iniciantes na programação, mas preciso muito da ajuda de vocês. grato pela compreensão!

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Citar

Desculpe-me pelas dúvidas, sou iniciantes na programação, mas preciso muito da ajuda de vocês. grato pela compreensão!

 

Tranquilo, geral começou um dia.


Provavelmente seu servidor não suporte mais o driver 
mysql_* (Repare na ausência do i -> mysqli_)

Exemplo completo de como usar o mysqli_* para listar todos os dados de uma coluna:

<?php
$dbhost = 'localhost';
$dbuser = 'root';
$dbpass = 'SUA_SENHA';
$dbname = 'cadeirajs';

$conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);


if(! $conn ) {
	die('Could not connect: ' . mysqli_error());
}

$sql = 'SELECT id FROM cadeiras';
$resultQuery = mysqli_query($conn, $sql);

$cadeiras = mysqli_fetch_all($resultQuery, MYSQLI_ASSOC);

foreach($cadeiras as $cadeira) {
	echo "Id: {$cadeira['id']}\n";
}




---- Obs:

Tenta sempre 'separar' o Sql para facilitar no Debbug futuro.

Ex:
Antes:

$sql = mysql_query ("INSERT INTO usuario.....


Depois:
 

$sqlStatment = "INSERT INTO usuario....."
$sql = mysql_query ($sqlStatment);

 

Assim você pode simplesmente 'exibir e parar' para debugar/depurar de forma mais assertiva;
Ex: de como 'parar' e exibir apenas a instrução SQL:

$sqlStatment = "INSERT INTO usuario....."
die($sqlStatment); // Vai exibir apenas o SQL
$sql = mysql_query ($sqlStatment);

Assim você tem acesso ao SQL, e executa ele manualmente no seu Banco de dados.
Enxergando algum errinho de sql/estrutura mais facilmente.

(Nada impede de rodar o SQL-Statement dentro do seu client de Mysql (MySqlAdmin.php / WorkBench, etc) e ver a resposta.

Att.


 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 28/03/2019 at 13:14, gabrieldarezzo disse:

Tranquilo, geral começou um dia.


Provavelmente seu servidor não suporte mais o driver 
mysql_* (Repare na ausência do i -> mysqli_)

Exemplo completo de como usar o mysqli_* para listar todos os dados de uma coluna:


<?php
$dbhost = 'localhost';
$dbuser = 'root';
$dbpass = 'SUA_SENHA';
$dbname = 'cadeirajs';

$conn = mysqli_connect($dbhost, $dbuser, $dbpass,$dbname);


if(! $conn ) {
	die('Could not connect: ' . mysqli_error());
}

$sql = 'SELECT id FROM cadeiras';
$resultQuery = mysqli_query($conn, $sql);

$cadeiras = mysqli_fetch_all($resultQuery, MYSQLI_ASSOC);

foreach($cadeiras as $cadeira) {
	echo "Id: {$cadeira['id']}\n";
}




---- Obs:

Tenta sempre 'separar' o Sql para facilitar no Debbug futuro.

Ex:
Antes:


$sql = mysql_query ("INSERT INTO usuario.....


Depois:
 


$sqlStatment = "INSERT INTO usuario....."
$sql = mysql_query ($sqlStatment);

 

Assim você pode simplesmente 'exibir e parar' para debugar/depurar de forma mais assertiva;
Ex: de como 'parar' e exibir apenas a instrução SQL:


$sqlStatment = "INSERT INTO usuario....."
die($sqlStatment); // Vai exibir apenas o SQL
$sql = mysql_query ($sqlStatment);

Assim você tem acesso ao SQL, e executa ele manualmente no seu Banco de dados.
Enxergando algum errinho de sql/estrutura mais facilmente.

(Nada impede de rodar o SQL-Statement dentro do seu client de Mysql (MySqlAdmin.php / WorkBench, etc) e ver a resposta.

Att.


 

Muito obrigado ! com sua a ajuda aqui de vocês consegui! mas outras dúvidas e problemas surgem no decorrer...

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
    • Por First
      Olá a todos!
       
      Quando eu tento fazer o login me mostra esse erro "Could not log you in."; Alguém sabe me ajudar a resolver esse problema no meu código?
      <?php require_once("core/init.php"); if (Input::exists()) { if (Token::check(Input::get("token"))) { $validate = new Validate(); $validation = $validate->check($_POST, array( "username" => array("required" => true), "password" => array("required" => true) )); if ($validation->passed()) { $user = new User(); $remember = (Input::get("remember")) === "on" ? true : false; $login = $user->login(Input::get("username"), Input::get("password"), $remember); if ($login) { Session::flash("home", "Welcome back!"); Redirect::to("index.php"); } else { echo "Could not log you in."; } } else { foreach ($validation->errors() as $error) { echo $error."<BR>"; } } } } ?> <form action="" method="POST"> <div class="field"> <label for="username">Username</label> <input type="text" name="username" id="username"> </div> <div class="field"> <label for="password">Password</label> <input type="password" name="password" id="password"> </div> <div class="field"> <label for="remember"> <input type="checkbox" name="remember" id="remember"> Remember me </label> </div> <input type="hidden" name="token" value="<?php echo Token::generate(); ?>"> <input type="submit" value="Log in"> </form>  
       
      Desde já obrigado.
    • Por ckcesar
      Eu tenho uma aplicação no zend com a versão 5.6 e com o postgresql 9.6. Agora eu precisei mudar a versão do meu postgresql para o 16.1, a parte de conexão do bd e consultas sqls funciona perfeitamente, o meu problema está para acessar os meus controllers. Eles não são encontrados em nenhuma rota, quero ver se alguém já passou por esse problema para me ajudar. Obrigado.
    • Por ILR master
      Fala galera, tudo bem?
       
      Tenho o seguinte codigo:
       
       class Data {
      public static function ExibirTempoDecorrido($date)
      {
          if(empty($date))
          {
              return "Informe a data";
          }
          $periodos = array("segundo", "minuto", "hora", "dia", "semana", "mês", "ano", "década");
          $duracao = array("60","60","24","7","4.35","12","10");
          $agora = time();
          $unix_data = strtotime($date);
          // check validity of date
          if(empty($unix_data))
          {  
              return "Bad date";
          }
          // is it future date or past date
          if($agora > $unix_data) 
          {  
              $diferenca     = $agora - $unix_data;
              $tempo         = "atrás";
          } 
          else 
          {
              $diferenca     = $unix_data - $agora;
              $tempo         = "agora";
          }
          for($j = 0; $diferenca >= $duracao[$j] && $j < count($duracao)-1; $j++) 
          {
              $diferenca /= $duracao[$j];
          }
          $diferenca = round($diferenca);
          if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
          return "$diferenca $periodos[$j] {$tempo}";
      }
      }
       
      Funciona redondinho se o valor retornado for de algumas horas, mas...
      Quando passa de dois meses, ele retorna a palavra mess. Deve ser por conta dessa linha
      if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
       
      Quero que modre:
       
      2 meses atrás
      e não
      2 mess atrás.
       
      Espero que tenham entendido.
       
      Valeu
×

Informação importante

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