Foros del Web » Programando para Internet » PHP »

Error al intentar conectarse con la base de datos

Estas en el tema de Error al intentar conectarse con la base de datos en el foro de PHP en Foros del Web. Mi problema es que cuando quiero enviar los datos de un formulario ( hecho en html y validado con js) a un archivo php (donde ...
  #1 (permalink)  
Antiguo 13/03/2008, 12:19
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Error al intentar conectarse con la base de datos

Mi problema es que cuando quiero enviar los datos de un formulario ( hecho en html y validado con js) a un archivo php (donde se conectara a la base y guarda los campos del anterior formulario) me aparece el siguiente error :
Parse error: syntax error, unexpected T_VARIABLE in E:\Archivos de programa\AppServ\www\lgi\alta.php on line 9
Y nose a que se debe, veo que no reconoce la variable donde guardo la conexion de la base de datos, ya que en la linea 9 esta esto:
Código PHP:
$dbh=mysql_connect ("localhost""root""pass") or die ('<br>No me puedo conectar con el servidor porque: ' mysql_error()); 
Bueno si alfuien me puede ayudar le doy las gracias, pongo el codigo del archivo alta.php, por las dudas:
Código PHP:
<?php

$seguro
=($valor*10)/100

$db
=mysql_connect ("localhost""root""pass") or die ('<br>No me puedo conectar con el servidor porque: ' mysql_error());

mysql_select_db ("autos");
  
$query="insert into seguro values ('".$patente."','".$marca."','".$modelo."','".$ano."','".$valor."','".$seguro."')";
  
$resultmysql_query ($query)
   if (
$result)
     echo 
mysql_affected_rows()."Vehiculo ha sido ingresado a la base de datos.";
     
?>
Nose si hace falta que lo diga, el formulario tiene 5 campos (patente,marca,modelo,año y valor), la variable $seguro calcula el 10% del valor del auto, la base se llama autos y la tabla seguro

Última edición por Durin; 13/03/2008 a las 12:53
  #2 (permalink)  
Antiguo 13/03/2008, 12:30
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Re: Error al intentar conecatrase con la base de datos

Te falta un punto y coma en esta linea, de hecho en todas las lineas, recuerda que en PHP los comandos terminan en ;:
Código PHP:
$seguro=($valor*10)/100
Saludos.
  #3 (permalink)  
Antiguo 13/03/2008, 12:30
Avatar de rogertm
Mod->Cuba
 
Fecha de Ingreso: julio-2005
Ubicación: /home/Cuba/Habana/rogertm/
Mensajes: 2.922
Antigüedad: 18 años, 9 meses
Puntos: 638
Re: Error al intentar conecatrase con la base de datos

fijate, te falta el punto y como en la linea anterior:
Código PHP:
$seguro=($valor*10)/100
saludos y suerte
__________________
Friki y Blogger por Cuenta Propia:213
Twenty'em: Theming is Prose
  #4 (permalink)  
Antiguo 13/03/2008, 12:32
Avatar de rogertm
Mod->Cuba
 
Fecha de Ingreso: julio-2005
Ubicación: /home/Cuba/Habana/rogertm/
Mensajes: 2.922
Antigüedad: 18 años, 9 meses
Puntos: 638
Re: Error al intentar conecatrase con la base de datos

Oops...! tambien te falta en la linea:
Código PHP:
$resultmysql_query ($query); 
__________________
Friki y Blogger por Cuenta Propia:213
Twenty'em: Theming is Prose
  #5 (permalink)  
Antiguo 13/03/2008, 13:22
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Re: Error al intentar conecatrase con la base de datos

Muchisimas grasicas a los dos, habia sido por eso, por no poner ";" en esas dos lineas ... hay que mirar mas!!!
Otra consulta, ¿por que cuando quiero ingresar otro registro, o sea mandar otro formulario, no me aparece el mensaje de : "Vehiculo ha sido ingresado a la base de datos." ? de la linea
Código PHP:
echo mysql_affected_rows()."Vehiculo ha sido ingresado a la base de datos."
Y tambien nose que pasa que cuando envio el formulario y despues aparece el mensaje de php, en realidad no envia nada, ya que cuando me fijo en la base de datos se agrega un registro pero en blanco, sin ninguna valor en los campos!!

Última edición por Durin; 13/03/2008 a las 13:45
  #6 (permalink)  
Antiguo 13/03/2008, 16:49
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Re: Error al intentar conectarse con la base de datos

De donde obtienes las variable $marca, $patente, $modelo, etc.?

Saludos.
  #7 (permalink)  
Antiguo 14/03/2008, 09:36
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Re: Error al intentar conectarse con la base de datos

de un formulario, echo en html, form seria asi:
Código PHP:
<form name="form1" action="alta.php" method="post" enctype="text/plain" id="cto_form1" onSubmit="javascript: return Validar_Form();" >
  <
label>Patente: <br>
  <
input type="text" name="patente"/>
  </
label>
  <
p>
 
    <
label>Marca: <br>
    <
input type="text" name="marca" />
    </
label>
 
  <
p>
    <
label>Modelo: <br>
    <
input type="text" name="modelo" />
    </
label>
   <
p>
   <
label>año: <br>
    <
input type="text" name="ano" />
    </
label>
    <
p>
     <
label>Valor: <br>
    <
input type="text" name="valor" />
    </
label>
    <
p>
      <
label>
      <
input type="submit" name="enviar" value="Enviar" />
      </
label>
      <
input type="reset" name="borrar" value="Borrar" />
      </
label>
     
    </
p>
  
</
form
Puede ser problema del action o del enctype?
  #8 (permalink)  
Antiguo 14/03/2008, 09:41
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Re: Error al intentar conectarse con la base de datos

Puede que tengas desactivado el register_globals por lo que en lugar de usar $marca deberas de usar $_POST['marca'];

También te recomiendo cambiar el enctype ya que en teoría debe de ser application/www-url-encoded (que es el valor por defecto), así que mejor deja tu form sin el enctype.

Saludos.
  #9 (permalink)  
Antiguo 14/03/2008, 10:37
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Re: Error al intentar conectarse con la base de datos

Y de donde activo el register_globals? y lo que me quieres decir sobre las variables, es hacer lo siguiente?:
$marca=$_POST['marca'];

Y el "$query" donde hago el alta de los campos, lo dejo tal cual esta?

Última edición por Durin; 14/03/2008 a las 10:49
  #10 (permalink)  
Antiguo 14/03/2008, 10:41
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Re: Error al intentar conectarse con la base de datos

Así es, la directiva register_globals se activa en el php.ini, pero no es recomendable ya que es un riesgo de seguridad, te recomiendo leas este tema:

http://www.forosdelweb.com/f18/varia...ontras-564845/

Saludos.
  #11 (permalink)  
Antiguo 14/03/2008, 13:51
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Re: Error al intentar conectarse con la base de datos

Gracias, me has ayudado realmente, ahora me ha surgido otro pequeño problema, en el mensaje que muestra en pantalla de que se ha ingresado un vehiculo:
Código PHP:
if ($result
     echo 
mysql_affected_rows()."Vehiculo ha sido ingresado a la base de datos."
Envez de aparecer el numero "1" y despues "Vehiculo....", parece con un "-", lo cual quedaria como negativo el numero 1, nose por que aparece eso
  #12 (permalink)  
Antiguo 14/03/2008, 14:04
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Re: Error al intentar conectarse con la base de datos

Porque cuando se envia el formulario correctamente, el archivo "alta.php" tiene unas lineas de html, donde pongo un titulo que dice: "ALTA DE VEHICULOS", despues pongo otra linea "Los datos del vehiculo han sido ingresados. Muchas Gracias." y debajo de esta ultima pongo la fila nueva, osea la linea que dice "1 Vehiculo ha sido ingresado a la base de datos", nose si tenga algo que ver del porque aparece un "-1"
  #13 (permalink)  
Antiguo 14/03/2008, 14:08
Avatar de jaronu  
Fecha de Ingreso: febrero-2008
Mensajes: 2.183
Antigüedad: 16 años, 2 meses
Puntos: 52
Re: Error al intentar conectarse con la base de datos

no se a que puede ser debido, pero en la BD tambien te aparece ese -1 o alli esta bien?
porque en definitiva eso es lo importante

Un saludo
  #14 (permalink)  
Antiguo 14/03/2008, 17:35
Avatar de Durin  
Fecha de Ingreso: febrero-2008
Ubicación: Argentina-Santa fe-Funes
Mensajes: 93
Antigüedad: 16 años, 2 meses
Puntos: 1
Re: Error al intentar conectarse con la base de datos

no, en la base no aparece ese uno, ya que esa instruccion "mysql_affected_rows" muestra las filas que fueron afectadas, en este caso como se esta ingresado un registro con los datos de un vehiculo, mostraria el numero "1"
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 20:17.