Foros del Web » Programando para Internet » PHP »

ingresar datos en mysql desde php

Estas en el tema de ingresar datos en mysql desde php en el foro de PHP en Foros del Web. NO PUEDO INGRESAR LOS DATOS A LA BASE DE DATOS EN MYSQL DESDE PHP NO SE CUAL ES MI ERROR SI ALGUIEN ME PUEDE AYUDAR ...
  #1 (permalink)  
Antiguo 18/07/2012, 23:12
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Sonrisa ingresar datos en mysql desde php

NO PUEDO INGRESAR LOS DATOS A LA BASE DE DATOS EN MYSQL DESDE PHP NO SE CUAL ES MI ERROR SI ALGUIEN ME PUEDE AYUDAR LO AGRADECERIA

LA BASE SE LLAMA montesinai
la tabla contratos

TODO LOS DATOS DE ESTE FORMULARIO:


</p>
<label>
<strong><h3 align="center">ALTA DE CONTRATO</h3></strong>
</label></p>


<br>

<FORM METHOD="POST" ACTION="insertarcon.php">
NOMBRE DEL ASESOR
<INPUT NAME="nombre_vend" TYPE="TEXT" size="40">
NUM. CONTRATO
<INPUT NAME="clave" TYPE="TEXT" size="20">
FOLIO
<INPUT NAME="folio" TYPE="TEXT" size="20">
FECHA
<INPUT NAME="fecha" TYPE="DATE">
<br>
<br>
TIPO DE SERVICIO
<select name="tipo_servicio">
<option value="IN" selected>IN </option>
<option value="CR">CR </option>
<option value="CR">IN2 </option>
<option value="CR2">CR2 </option>
<option value="CR">IN3 </option>
<option value="CR2">CR3 </option>
</select>
COSTO SERVICIO
<select name="costo_servicio">
<option value="10900" selected>10900 </option>
<option value="15900">15900 </option>
<option value="21800">21800 </option>
<option value="31800">31800 </option>
<option value="32700">32700 </option>
<option value="47700"> 47700 </option>
</select>
AP. INICIAL
<INPUT NAME="ap_ini" TYPE="TEXT" size="13">

SALDO
<INPUT NAME="saldo" TYPE="TEXT" size="13">
T. ABONO
<select name="abono">
<option value="SEMANAL" selected>SEMANAL </option>
<option value="QUINCENAL">QUINCENAL </option>
<option value="MENSUAL">MENSUAL </option>

</select>
<br>
<br>
NOMBRE CLIENTE
<INPUT NAME="nom_cliente" TYPE="TEXT" size="45">
EDAD
<INPUT NAME="edad_cliente" TYPE="TEXT" size="10">
F. NAC.
<INPUT NAME="fecha_n" TYPE="DATE" size="20">
DIRECCION
<INPUT NAME="dir_cliente" TYPE="TEXT" size="40">

<br>
<BR>
TELEFONO
<INPUT TYPE="TEXT" INPUT NAME="tel_cliente">
<br>
<br>
COTITULAR 1
<INPUT NAME="cotitular1" TYPE="TEXT" size="45" INPUT>
PARENTESCO
<INPUT TYPE="TEXT" INPUT NAME="parentesco1">
<BR>
COTITULAR 2
<INPUT NAME="cotitular2" TYPE="TEXT" size="45" INPUT>
PARENTESCO
<INPUT TYPE="TEXT" INPUT NAME="parentesco2">
<BR>
COTITULAR 3
<INPUT NAME="cotitular3" TYPE="TEXT" size="45" INPUT>
PARENTESCO
<INPUT TYPE="TEXT" NAME="parentesco3"><BR /><BR />


<INPUT TYPE="SUBMIT" value="INSERTAR">
</FORM>
</div>
</div>



Y LOS RECIBO EN ESTA PAGINA DE CODIGO PHP:


<?
$link = @mysql_connect("localhost", "root","")
or die ("Error al conectar a la base de datos.");
@mysql_select_db("montesinai", $link)
or die ("Error al conectar a la base de datos.");
mysql_query("INSERT INTO contratos (nombre_vend,clave,folio,fecha,tipo_servicio,costo _servicio,ap_ini,saldo,abono,nom_cliente,edad_clie nte,fecha_n,dir_cliente,tel_cliente,cotitular1,par entesco1,cotitular2,parentesco2,cotitular3,parente sco3) VALUES ('$nombre_vend','$clave,'$folio','$fecha','$tipo_s ervicio','$costo_servicio','$ap_ini','$saldo','$ab ono','$nom_cliente','$edad_cliente','$fecha_n','$d ir_cliente','$tel_cliente','$cotitular1','$parente sco1','$cotitular2','$parentesco2','$cotitular3',' $parentesco3')");
?>
  #2 (permalink)  
Antiguo 19/07/2012, 00:00
Avatar de Nopal_Studio  
Fecha de Ingreso: julio-2012
Ubicación: DF
Mensajes: 42
Antigüedad: 11 años, 9 meses
Puntos: 10
Información Respuesta: ingresar datos en mysql desde php

Hola ESANTOS87, considero que tu error esta en que: Cuando estas agregando las variables en el VALUES, no estas indicando correctamente su uso, es decir deberian ser:

Código PHP:
Ver original
  1. $nombre_vend = $_POST['nombre_vend'];
  2. $clave = $_POST['clave'];
  3. $folio = $_POST['fecha'];
  4. // y asi con todas las demas variables
  5.  
  6. VALUES ('$nombre_vend','$clave,'$folio','$fecha','$tipo_s ervicio','$costo_servicio','$ap_ini','$saldo','$ab ono','$nom_cliente','$edad_cliente','$fecha_n','$d ir_cliente','$tel_cliente','$cotitular1','$parente sco1','$cotitular2','$parentesco2','$cotitular3',' $parentesco3')");

éxito, que todo salga de maravilla
  #3 (permalink)  
Antiguo 19/07/2012, 00:37
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Respuesta: ingresar datos en mysql desde php

PUES MIRA YA CAMBIE EL CODIGO A COMO ME RECOMENDASTE Y QUEDO ASI:

Código PHP:
Ver original
  1. <?
  2. $link = @mysql_connect("localhost", "root","")
  3.       or die ("Error al conectar a la base de datos.");
  4.   @mysql_select_db("montesinai", $link)
  5.       or die ("Error al conectar a la base de datos.");
  6. $nombre_vend = $_POST['nombre_vend'];
  7. $clave = $_POST['clave'];
  8. $folio = $_POST['folio'];
  9. $fecha = $_POST['fecha'];
  10. $tipo_servicio = $_POST['tipo_servicio'];
  11. $costo_servicio = $_POST['costo_servicio'];
  12. $ap_ini = $_POST['ap_ini'];
  13. $saldo = $_POST['saldo'];
  14. $abono = $_POST['abono'];
  15. $nom_cliente = $_POST['nom_cliente'];
  16. $edad_cliente = $_POST['edad_cliente'];
  17. $fecha_n = $_POST['fecha_n'];
  18. $dir_cliente = $_POST['dir_cliente'];
  19. $tel_cliente = $_POST['tel_cliente'];
  20. $cotitular1 = $_POST['cotitular1'];
  21. $parentesco1 = $_POST['parentesco1'];
  22. $cotitular2 = $_POST['cotitular2'];
  23. $parentesco2 = $_POST['parentesco2'];
  24. $cotitular3 = $_POST['cotitular3'];
  25. $parentesco3 = $_POST['parentesco3'];
  26. mysql_query("INSERT INTO contratos (nombre_vend,clave,folio,fecha,tipo_servicio,costo_servicio,ap_ini,saldo,abono,nom_cliente,edad_cliente,fecha_n,dir_cliente,tel_cliente,cotitular1,parentesco1,cotitular2,parentesco2,cotitular3,parentesco3) VALUES ('$nombre_vend','$clave,'$folio','$fecha','$tipo_servicio','$costo_servicio','$ap_ini','$saldo','$abono','$nom_cliente','$edad_cliente','$fecha_n','$dir_cliente','$tel_cliente','$cotitular1','$parentesco1','$cotitular2','$parentesco2','$cotitular3','$parentesco3')");
  27. ?>


Y AUN ASI NO ME INGRESA LOS DATOS QUE SERA QUE ME FALLA? ALGUNA OTRA AYUDA??
  #4 (permalink)  
Antiguo 19/07/2012, 00:58
webankenovi
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: ingresar datos en mysql desde php

añade or die(mysql_error()) a la consulta para ver que falla y nos cuentas
  #5 (permalink)  
Antiguo 19/07/2012, 01:11
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Respuesta: ingresar datos en mysql desde php

Disculpa en que parte pongo or die
  #6 (permalink)  
Antiguo 19/07/2012, 01:13
webankenovi
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: ingresar datos en mysql desde php

al final de la consulta ........co2','$cotitular3','$parentesco3')") or die (mysql_error());
  #7 (permalink)  
Antiguo 19/07/2012, 01:40
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Respuesta: ingresar datos en mysql desde php

ME APARECIO ESTO

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '23933','2012-07-25','IN','10900','100','10800','QUINCENAL','JHONNY RAUL JIMENEZ ' at line 1
  #8 (permalink)  
Antiguo 19/07/2012, 01:54
Avatar de rodrigo791  
Fecha de Ingreso: noviembre-2009
Ubicación: Uruguay
Mensajes: 1.339
Antigüedad: 14 años, 5 meses
Puntos: 168
Respuesta: ingresar datos en mysql desde php

Código PHP:
Ver original
  1. $consulta = "INSERT INTO contratos (nombre_vend,clave,folio,fecha,tipo_servicio,costo_servicio,ap_ini,saldo,abono,nom_cliente,edad_cliente,fecha_n,dir_cliente,tel_cliente,cotitular1,parentesco1,cotitular2,parentesco2,cotitular3,parentesco3) VALUES ('$nombre_vend','$clave,'$folio','$fecha','$tipo_servicio','$costo_servicio','$ap_ini','$saldo','$abono','$nom_cliente','$edad_cliente','$fecha_n','$dir_cliente','$tel_cliente','$cotitular1','$parentesco1','$cotitular2','$parentesco2','$cotitular3','$parentesco3')";
  2. mysql_query($consulta, $link);

En mysql_query el 2do parametro es la variable de conexión en este caso $link,
proba con eso
  #9 (permalink)  
Antiguo 19/07/2012, 02:03
webankenovi
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: ingresar datos en mysql desde php

si no te funca lo que dijo rodrigo ,

- Comprueba que todas las variables llegan correctamente a la pagina que procesa el formulario
echo $_POST['aquielvalor']

- Comprueba los nombres de la consulta coinciden con los de la tabla

- Comprueba los caracteres que diste en la tabla son iguales a los del form
  #10 (permalink)  
Antiguo 19/07/2012, 02:06
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Respuesta: ingresar datos en mysql desde php

tampoco me funciono antes tenia menos campos en la tabla pero agregue algunos y fue cuando ya no me funciono y no pude agregar registros
  #11 (permalink)  
Antiguo 19/07/2012, 02:28
 
Fecha de Ingreso: julio-2012
Ubicación: Girona
Mensajes: 63
Antigüedad: 11 años, 9 meses
Puntos: 10
Respuesta: ingresar datos en mysql desde php

Parece como si hubiera un problema con los datos (como si pasaras una comilla simple),
antes del mysql_query() haz un print_r($_POST) y péganos el resultado aquí a ver si vemos algun carácter extraño.

Saludos
  #12 (permalink)  
Antiguo 19/07/2012, 02:41
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Respuesta: ingresar datos en mysql desde php

puse el print_r($_POST); antes de realizar el insert y me salio esto

Array ( [nombre_vend] => erik christian santos gonzalez [clave] => 12345 [folio] => 67890 [fecha] => 2012-07-02 [tipo_servicio] => IN [costo_servicio] => 10900 [ap_ini] => 100 [saldo] => 10800 [abono] => MENSUAL [nom_cliente] => jhonny raul jimenez perez [edad_cliente] => 24 [fecha_n] => 2012-07-03 [dir_cliente] => conocida [tel_cliente] => 9374826582 [cotitular1] => conocida1 [parentesco1] => conocido1 [cotitular2] => conocida2 [parentesco2] => conocido2 [cotitular3] => conocida3 [parentesco3] => conocido4 )
  #13 (permalink)  
Antiguo 19/07/2012, 02:47
 
Fecha de Ingreso: julio-2012
Mensajes: 8
Antigüedad: 11 años, 9 meses
Puntos: 0
Respuesta: ingresar datos en mysql desde php

bueno creo que ya me hice un lio mi codigo esta asi actualmente el formulario es este:

Código HTML:
Ver original
  1. <FORM METHOD="POST" ACTION="insertarcon.php">
  2.  NOMBRE DEL ASESOR
  3. <INPUT TYPE="TEXT" NAME="nombre_vend" size="40">    
  4. NUM. CONTRATO
  5. <INPUT TYPE="TEXT" NAME="clave" size="20">
  6. FOLIO
  7. <INPUT TYPE="TEXT" NAME="folio" size="20">
  8. FECHA
  9. <INPUT TYPE="DATE"  NAME="fecha">
  10. <br>
  11. <br>
  12. TIPO DE SERVICIO
  13. <select name="tipo_servicio">
  14.   <option value="IN" selected>IN  </option>
  15.   <option value="CR">CR           </option>
  16.   <option value="CR">IN2          </option>
  17.   <option value="CR2">CR2         </option>
  18.   <option value="CR">IN3          </option>
  19.   <option value="CR2">CR3         </option>
  20. COSTO SERVICIO
  21. <select name="costo_servicio">
  22.   <option value="10900" selected>10900          </option>
  23.   <option value="15900">15900          </option>
  24.     <option value="21800">21800          </option>
  25.   <option value="31800">31800          </option>
  26.   <option value="32700">32700       </option>
  27.   <option value="47700">  47700       </option>
  28. AP. INICIAL
  29. <INPUT TYPE="TEXT"  NAME="ap_ini" size="13">
  30.  
  31. SALDO
  32. <INPUT  TYPE="TEXT" NAME="saldo" size="13">
  33. T. ABONO
  34. <select name="abono">
  35.   <option value="SEMANAL" selected>SEMANAL          </option>
  36.   <option value="QUINCENAL">QUINCENAL          </option>
  37.     <option value="MENSUAL">MENSUAL       </option>
  38.  
  39. <br>
  40. <br>
  41. NOMBRE CLIENTE
  42. <INPUT  TYPE="TEXT" NAME="nom_cliente" size="45">
  43. EDAD
  44. <INPUT TYPE="TEXT"   NAME="edad_cliente" size="10">
  45. F. NAC.
  46. <INPUT  TYPE="DATE" NAME="fecha_n" size="20">
  47. DIRECCION
  48. <INPUT TYPE="TEXT" NAME="dir_cliente" size="40">
  49.  
  50. <br>
  51. <BR>
  52. TELEFONO
  53. <INPUT TYPE="TEXT" NAME="tel_cliente">
  54. <br>
  55. <br>
  56. COTITULAR 1
  57. <INPUT TYPE="TEXT" NAME="cotitular1" size="45" >
  58. PARENTESCO
  59. <INPUT TYPE="TEXT" NAME="parentesco1">
  60. <BR>
  61. COTITULAR 2
  62. <INPUT TYPE="TEXT" NAME="cotitular2" size="45">
  63. PARENTESCO
  64. <INPUT TYPE="TEXT" NAME="parentesco2">
  65. <BR>
  66. COTITULAR 3
  67. <INPUT TYPE="TEXT" NAME="cotitular3" size="45" >
  68. PARENTESCO
  69. <INPUT TYPE="TEXT"  NAME="parentesco3"><BR /><BR />
  70.  
  71.  
  72.     <INPUT TYPE="SUBMIT" value="INSERTAR">
  73.     </FORM>

y el codigo php donde recibo los datos esta asi:

Código PHP:
Ver original
  1. <?
  2. $link = @mysql_connect("localhost", "root","")
  3.       or die ("Error al conectar a la base de datos.");
  4.   @mysql_select_db("montesinai", $link)
  5.       or die ("Error al conectar a la base de datos.");
  6. $nombre_vend =$_POST["nombre_vend"];
  7. $clave = $_POST['clave'];
  8. $folio = $_POST['folio'];
  9. $fecha = $_POST['fecha'];
  10. $tipo_servicio = $_POST['tipo_servicio'];
  11. $costo_servicio = $_POST['costo_servicio'];
  12. $ap_ini = $_POST['ap_ini'];
  13. $saldo = $_POST['saldo'];
  14. $abono = $_POST['abono'];
  15. $nom_cliente = $_POST['nom_cliente'];
  16. $edad_cliente = $_POST['edad_cliente'];
  17. $fecha_n = $_POST['fecha_n'];
  18. $dir_cliente = $_POST['dir_cliente'];
  19. $tel_cliente = $_POST['tel_cliente'];
  20. $cotitular1 = $_POST['cotitular1'];
  21. $parentesco1 = $_POST['parentesco1'];
  22. $cotitular2 = $_POST['cotitular2'];
  23. $parentesco2 = $_POST['parentesco2'];
  24. $cotitular3 = $_POST['cotitular3'];
  25. $parentesco3 = $_POST['parentesco3'];
  26. print_r($_POST);
  27. $consulta="INSERT INTO contratos (nombre_vend,clave,folio,fecha,tipo_servicio,costo_servicio,ap_ini,saldo,abono,nom_cliente,edad_cliente,fecha_n,dir_cliente,tel_cliente,cotitular1,parentesco1,cotitular2,parentesco2,cotitular3,parentesco3) VALUES ('$nombre_vend','$clave','$folio','$fecha','$tipo_servicio','$costo_servicio','$ap_ini','$saldo','$abono','$nom_cliente','$edad_cliente','$fecha_n','$dir_cliente','$tel_cliente','$cotitular1','$parentesco1','$cotitular2','$parentesco2','$cotitular3','$parentesco3')"or die (mysql_error());
  28.  
  29. mysql_query($consulta, $link);
  30. @mysql_close($link);
  31. ?>

mi tabla es esta:


Campo Tipo Cotejamiento Atributos Nulo Predeterminado Extra Acción
nombre_vend text latin1_swedish_ci No
clave int(11) No
folio text latin1_swedish_ci No
fecha date No
tipo_servicio text latin1_swedish_ci No
costo_servicio text latin1_swedish_ci No
ap_ini text latin1_swedish_ci No
saldo text latin1_swedish_ci No
abono text latin1_swedish_ci No
nom_cliente text latin1_swedish_ci No
edad_cliente text latin1_swedish_ci No
fecha_n date No
dir_cliente text latin1_swedish_ci No
tel_cliente text latin1_swedish_ci No
cotitular1 text latin1_swedish_ci No
parentesco1 text latin1_swedish_ci No
cotitular2 text latin1_swedish_ci No
parentesco2 text latin1_swedish_ci No
cotitular 3 text latin1_swedish_ci No
parentesco3 text latin1_swedish_ci No
  #14 (permalink)  
Antiguo 19/07/2012, 02:52
 
Fecha de Ingreso: julio-2012
Ubicación: Girona
Mensajes: 63
Antigüedad: 11 años, 9 meses
Puntos: 10
Respuesta: ingresar datos en mysql desde php

Prueba a cambiar tu mysql_query por este:

Cita:
Código PHP:
Ver original
  1. mysql_query('INSERT INTO contratos (nombre_vend,clave,folio,fecha,tipo_servicio,costo_servicio,ap_ini,saldo,abono,nom_cliente,edad_cliente,fecha_n,dir_cliente,tel_cliente,cotitular1,parentesco1,cotitular2,parentesco2,cotitular3,parentesco3) VALUES ("'.$nombre_vend.'",'.$clave.','.$folio.',"'.$fecha.'","'.$tipo_servicio.'",'.$costo_servicio.',"'.$ap_ini.'",'.$saldo.',"'.$abono.'","'.$nom_cliente.'",'.$edad_cliente.',"'.$fecha_n.'","'.$dir_cliente.'","'.$tel_cliente.'","'.$cotitular1.'","'.$parentesco1.'","'.$cotitular2.'","'.$parentesco2.'","'.$cotitular3.'","'.$parentesco3.')',$link)
Tienes que poner comillas delante de los campos que sean texto, si no te dará error al ejecutar la query;

Etiquetas: sql
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:38.