Foros del Web » Programando para Internet » PHP »

insertar un registro. ERROR

Estas en el tema de insertar un registro. ERROR en el foro de PHP en Foros del Web. Hola. Intento insertar un registro en una tabla. La conexión está bien porque hace correctamente la select() pero la inserción NO hay manera Código HTML: ...
  #1 (permalink)  
Antiguo 11/11/2015, 08:51
 
Fecha de Ingreso: marzo-2012
Mensajes: 45
Antigüedad: 12 años, 7 meses
Puntos: 0
insertar un registro. ERROR

Hola. Intento insertar un registro en una tabla.
La conexión está bien porque hace correctamente la select() pero la inserción NO hay manera

Código HTML:
<html>
<head>
	<title>Formulario de Alta</title>
	<link rel="stylesheet" type="text/css" href="formulario.css" media="all" />
	<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
</head>

<body>
<form id="formulario" action="enviado.php" method="post">
    <fieldset>
        <legend>Formulario de Ejemplo</legend>
            <label>DNI</label>
                <input id="campo1" name="dni" type="text" />
            <label>Nombre</label>
                <input id="campo2" name="nombre" type="text" />
			<label>Apellidos</label>
                <input id="campo3" name="apellidos" type="text" />
			<label>Teléfono</label>
                <input id="campo4" name="telefono" type="text" />
            <input id="campo5" name="enviar" type="submit" value="Enviar" />
    </fieldset>
</form>
</body>
</html> 
Y el PHP

Código HTML:
<html> 
<body>
<head>
	<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
</head> 
<?php 
	
	error_reporting(E_ERROR);
	mysql_connect("localhost","root",""); 
	mysql_query("SET NAMES 'utf8'");
	mysql_select_db("academia"); 
	//Ejecucion de la sentencia SQL
	mysql_query("insert into persona (dni,nombre,apellidos,telefono) values ($_POST['dni'],$_POST['nombre'],$_POST['apellidos'],$_POST['telefono'])");
?>
<h1><div align="center">Registro Insertado</div></h1>
</body> 
</html> 
ERROR en la linea del INSERT:

Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in C:\wamp\www\proyecto1\enviado.php on line 13

Muchas Gracias
  #2 (permalink)  
Antiguo 11/11/2015, 08:59
 
Fecha de Ingreso: septiembre-2015
Mensajes: 70
Antigüedad: 9 años, 1 mes
Puntos: 4
Respuesta: insertar un registro. ERROR

mira prueba asi



mysql_query("insert into persona (dni,nombre,apellidos,telefono) values (".$_POST['dni'].", ".$_POST['nombre'].", ".$_POST['apellidos'].", ".$_POST['telefono'].")");
  #3 (permalink)  
Antiguo 11/11/2015, 09:58
 
Fecha de Ingreso: marzo-2012
Mensajes: 45
Antigüedad: 12 años, 7 meses
Puntos: 0
Respuesta: insertar un registro. ERROR

Hola.

Ahora no dá error, pero tampoco inserta el el registro.

No lo entiendo.
  #4 (permalink)  
Antiguo 11/11/2015, 10:56
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 7 meses
Puntos: 2534
Respuesta: insertar un registro. ERROR

Cita:
No lo entiendo.
Te sugiero leer una referencia de SQL antes que nada, porque si no entiendes la sintaxis correcta ¿cómo pretendes hacer consultas?

En teoría los valores de texto deben llevar comillas simples:

Código PHP:
Ver original
  1. // MAL
  2.  mysql_query("insert into persona (dni,nombre,apellidos,telefono) values (".$_POST['dni'].", ".$_POST['nombre'].", ".$_POST['apellidos'].", ".$_POST['telefono'].")");
  3.  
  4. // BIEN
  5.  mysql_query("insert into persona (dni,nombre,apellidos,telefono) values ('{$_POST['dni']}', '{$_POST['nombre']}', '{$_POST['apellidos']}', '{$_POST['telefono']}')");

Lean, ambos, lo siguiente: http://www.forosdelweb.com/f18/como-...s-bien-588701/
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.

Etiquetas: formulario, html, mysql, registro, select, sql, tabla, variable
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 21:25.