Foros del Web » Programando para Internet » PHP »

Insertar un registro a la base de datos

Estas en el tema de Insertar un registro a la base de datos en el foro de PHP en Foros del Web. Hola gentes tengo este codigo que es para subir unas fotos al servidor funka de 10, pero tambien quiero agregarle que al subir la info ...
  #1 (permalink)  
Antiguo 12/06/2009, 11:09
 
Fecha de Ingreso: agosto-2008
Mensajes: 97
Antigüedad: 15 años, 8 meses
Puntos: 1
Insertar un registro a la base de datos

Hola gentes tengo este codigo que es para subir unas fotos al servidor funka de 10, pero tambien quiero agregarle que al subir la info con este codigo me llene otros campos de la base de datos, les dejo mi codigo y como lo arme, pero no logro hacer que me suba la info a la base. Mil Gracias por cualquier ayuda!!!


Código HTML:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<html>
<head>
	<title>Subir archivos</title>
	<link rel="STYLESHEET" type="text/css" href="estilos_admin.css">
</head>

<body>
<h1>Subir archivos</h1>
<br>
	<form action="subearchivo.php" method="post" enctype="multipart/form-data">
		<p><b>Campo de tipo texto:</b> 
		    <br>
		    <input type="text" name="cadenatexto" size="20" maxlength="100">
		  <input type="hidden" name="MAX_FILE_SIZE" value="100000">
	    </p>
		<p>Producto	  </p>
		<p>
		  <input type="text" name="producto" size="20" maxlength="100">
		  <br>
		  <br>
		  <b>Enviar un nuevo archivo: </b>
		  <br>
		  <input name="userfile" type="file">
	    </p>
	  <p>&nbsp;</p>
		<p><br>
		    <input type="submit" value="Enviar">
	          </p>
</form>
</body>
</html>


Código PHP:
<?php
mysql_connect
("info de la base de datos");
mysql_select_db("carro");

echo 
$_POST['cadenatexto']." Nombres<br>";
if (
$_POST['cadenatexto']!='')
{


$path=$dir."/img_productos/";
$path2="img_productos/";
$nombre_archivo $_FILES['userfile']['name'];
$tipo_archivo $_FILES['userfile']['type'];
$tamano_archivo $_FILES['userfile']['size'];
$producto $_POST['producto'];
if (!((
strpos($nombre_archivo"doc") || strpos($nombre_archivo"gif") || strpos($nombre_archivo,"jpg"))))
{
echo 
"La extensión o el tamaño de los archivos no es correcta";
}
else
{
if (
move_uploaded_file($_FILES['userfile']['tmp_name'], $path2.$_FILES['userfile']['name']))
{
$sql_i "INSERT INTO carro(imagen,descripcion,producto) VALUES('".$path2.$_FILES['userfile']['name']."', 'DESCRIPCION', ".$producto.")";   
$r mysql_query($sql_i);

echo 
"El archivo ha sido cargado correctamente.";
}
else
{
echo 
"Ocurrió algún error al subir el fichero. No pudo guardarse.";
}
}
}
?>
<br>
<br>

<a href="index.php">Volver</a>
<br>
</div>
</body>
</html>
  #2 (permalink)  
Antiguo 12/06/2009, 11:16
Avatar de Synkronice  
Fecha de Ingreso: octubre-2007
Ubicación: Madrid
Mensajes: 831
Antigüedad: 16 años, 6 meses
Puntos: 48
Respuesta: Insertar un registro a la base de datos

En estos casos lo mejor es 'debugear', para empezar verifica que la cadena de la consulta se este formando correctamente haciendo un echo de $sql_i. Tambien haz un echo de los posibles errores que este devolviendo la base de datos al intentar ejecutar la consulta de inserccion.

Mas info sobre como pintar errores en las consultas....

http://es2.php.net/manual/es/function.mysql-error.php

Saludos!
  #3 (permalink)  
Antiguo 12/06/2009, 11:33
 
Fecha de Ingreso: agosto-2008
Mensajes: 97
Antigüedad: 15 años, 8 meses
Puntos: 1
Respuesta: Insertar un registro a la base de datos

Hice lo q me dijiste y sigo sin encontrar el error! Mil gracias por comentar!!
  #4 (permalink)  
Antiguo 12/06/2009, 11:38
Avatar de Synkronice  
Fecha de Ingreso: octubre-2007
Ubicación: Madrid
Mensajes: 831
Antigüedad: 16 años, 6 meses
Puntos: 48
Respuesta: Insertar un registro a la base de datos

Tienes que averiguar si entra en el IF que hace la consulta de insercción, eso has de hacerlo 'debugueando'. Puedes ayudarte de con echo's. Vuelve a pegar el código con los cambios que te he recomendado para y dime en que IF o ELSE estás entrando.

Has verificado si el archivo se está subiendo al servidor en el IF que usa la funcion move_uploaded_file()?

Saludos!
  #5 (permalink)  
Antiguo 12/06/2009, 12:17
Avatar de cesarpunk  
Fecha de Ingreso: enero-2008
Ubicación: Lima
Mensajes: 943
Antigüedad: 16 años, 3 meses
Puntos: 9
Respuesta: Insertar un registro a la base de datos

por lo que veo esa tabla no tiene ID .... y si lo tuviera supongo que es autonumeric porque podrias hacer esto:

Código PHP:
<php

$sql_i 
"INSERT INTO carro VALUES(NULL,'".$path2.$_FILES['userfile']['name']."', 'DESCRIPCION', ".$producto.")";


?> 
y por recomensacion hasle un echo a $sql_i a ver si coge los valores
__________________
Quitenme la vida pero no la bebida.
  #6 (permalink)  
Antiguo 12/06/2009, 12:57
 
Fecha de Ingreso: agosto-2008
Mensajes: 97
Antigüedad: 15 años, 8 meses
Puntos: 1
Respuesta: Insertar un registro a la base de datos

este es el nuevo codigo y si cuando le pongo un echo a $sql me tira los valores q yo le pongo

<?php
mysql_connect("");
mysql_select_db("carro");

echo $_POST['cadenatexto']." Nombres<br>";
if ($_POST['cadenatexto']!='')
{


$path=$dir."/img_productos/";
$path2="img_productos/";
$nombre_archivo = $_FILES['userfile']['name'];
$tipo_archivo = $_FILES['userfile']['type'];
$tamano_archivo = $_FILES['userfile']['size'];
$producto = $_POST['producto'];
if (!((strpos($nombre_archivo, "doc") || strpos($nombre_archivo, "gif") || strpos($nombre_archivo,"jpg"))))
{
echo "La extensión o el tamaño de los archivos no es correcta";
}
else
{
if (move_uploaded_file($_FILES['userfile']['tmp_name'], $path2.$_FILES['userfile']['name']))
{
echo
$sql_i = "INSERT INTO carro(imagen,descripcion,producto) VALUES('".$path2.$_FILES['userfile']['name']."', 'DESCRIPCION', ".$producto.")";
$r = mysql_query($sql_i);

echo "El archivo ha sido cargado correctamente.";
}
else
{
echo "Ocurrió algún error al subir el fichero. No pudo guardarse.";
}
}
}
?>
<br>
<br>

<a href="index.php">Volver</a>
<br>
</div>
</body>
</html>
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 11:36.