Foros del Web » Programando para Internet » PHP »

guardar texto con espacio en un campo bd

Estas en el tema de guardar texto con espacio en un campo bd en el foro de PHP en Foros del Web. Buen dia, Tengo el siguiente problema en mi tabla materia hay un campo que se llama descripcion de tipo varchar 20, el cual el contenido ...
  #1 (permalink)  
Antiguo 16/02/2010, 08:59
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
guardar texto con espacio en un campo bd

Buen dia,

Tengo el siguiente problema en mi tabla materia hay un campo que se llama descripcion de tipo varchar 20, el cual el contenido debe tener espacio en blanco por ejemplo "matematica 1" ó "lenguaje de programacion".

En php al momento de ingresar el valor para este campo me hace lo siguiente:

ejemplo:

campo de texto:lenguaje de programacion

valor insertado con php en la bd mysql: lenguaje.

Pareciera que al encontrar el primer espacio deja de guardar.

¿No hay una forma de que con php al momento de hacer el insert en la tabla materia, me guarde con los espacios en blanco?

Desde ya mucha gracias por su ayuda brindada
  #2 (permalink)  
Antiguo 16/02/2010, 09:14
 
Fecha de Ingreso: febrero-2010
Mensajes: 818
Antigüedad: 14 años, 2 meses
Puntos: 55
Respuesta: guardar texto con espacio en un campo bd

si el problema solo lo tienes en el de lenguaje de programación puede ser que el valor ingresado es mayor al definido en la tabla.

poruqe la bd tiene que guardar los espacios en blanco poruqe tambien son caracteres
is haces insert into tabla(nombre) values("Juan el Gato"); tiene que guardarlo. a lo mejor no le estas pasando bien el valor al insert.
  #3 (permalink)  
Antiguo 16/02/2010, 09:41
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: guardar texto con espacio en un campo bd

El problema puede ser a la hora de imprimir el valor en tu campo de texto, es obligatorio que sea value="" con las comillas si no pasa eso que indicas.

Saludos.
  #4 (permalink)  
Antiguo 16/02/2010, 11:00
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
Respuesta: guardar texto con espacio en un campo bd

el problema no es bd porquer puedo hacer insert desde MySQL. el problema es que si en un campo de texto llamado T1 acepta una cadena de caracter.

al hacer el insert desde PHP seria el siguiente:

$sql=("SELECT * FROM materias WHERE cod_materia ='$t1' ");

Sera que tengo algo malo en mi insert que no me coloca la cadena completa al encontrar un espacio en blanco?
  #5 (permalink)  
Antiguo 16/02/2010, 11:04
Avatar de darkasecas  
Fecha de Ingreso: marzo-2005
Ubicación: SantaCata, NL, Mexico
Mensajes: 1.553
Antigüedad: 19 años, 1 mes
Puntos: 77
Respuesta: guardar texto con espacio en un campo bd

Por que imprimes tus variables/consulta para ver si tienen el valor correcto?

Ademas
Cita:
Iniciado por GatorV Ver Mensaje
El problema puede ser a la hora de imprimir el valor en tu campo de texto, es obligatorio que sea value="" con las comillas si no pasa eso que indicas.

Saludos.
  #6 (permalink)  
Antiguo 16/02/2010, 11:24
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
Respuesta: guardar texto con espacio en un campo bd

de esta manera me permite guardar texto con espacios en blanco pero al buscarlo me trae el texto incompleto:

Código:
<input name="t2" type="text" id="t2" size="22" maxlength="22" value=<?php print (nl2br($nombre));?> >
y me esta afectando hasta para eliminar el registro, no lo hace porq ve el campo clave como "indefinido".
  #7 (permalink)  
Antiguo 16/02/2010, 11:28
Avatar de hector2c  
Fecha de Ingreso: noviembre-2007
Ubicación: Perú - Tacna
Mensajes: 979
Antigüedad: 16 años, 5 meses
Puntos: 25
Respuesta: guardar texto con espacio en un campo bd

patricia, por que pones nl2br ???, eso hace que se generen saltos de linea... evita agregar esa función php, usalo en textarea, has visto si el texto se guarda adecuadamente en tu bd mysql?
__________________
blog: hector2c.wordpress.com
email: [email protected]
  #8 (permalink)  
Antiguo 16/02/2010, 11:41
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
Respuesta: guardar texto con espacio en un campo bd

al hacer el query directo en la bd me lo muestra correctamente, pero al buscarlo en php me sale incompleto.

Y quitando la funcion nl2br ni siquiera lo inserta.
  #9 (permalink)  
Antiguo 16/02/2010, 11:45
Avatar de hector2c  
Fecha de Ingreso: noviembre-2007
Ubicación: Perú - Tacna
Mensajes: 979
Antigüedad: 16 años, 5 meses
Puntos: 25
Pregunta Respuesta: guardar texto con espacio en un campo bd

puedes mostrar el código php que generas para hacer la consulta???... a la vez, intenta con esto (observa las dobles comillas que van al value):

Código PHP:
<input value="<?=$nombre;?>">
espero tu respuesta...
__________________
blog: hector2c.wordpress.com
email: [email protected]
  #10 (permalink)  
Antiguo 16/02/2010, 11:46
 
Fecha de Ingreso: febrero-2010
Mensajes: 818
Antigüedad: 14 años, 2 meses
Puntos: 55
Respuesta: guardar texto con espacio en un campo bd

y asi no te funciona
Código:
<input name="t2" type="text" id="t2" size="22" maxlength="22" value="<?=$nombre ?>" >
  #11 (permalink)  
Antiguo 16/02/2010, 13:06
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
Respuesta: guardar texto con espacio en un campo bd

este es el codigo de buscar:

Código:
<?
if (isset($cmdbuscar))
{
  if(empty($t1))
  {
   echo '<script>alert("Por favor llene todos los campos.");</script>';
  }
  else
  {
   
   $con=mysql_connect("localhost","root","123");
   mysql_select_db("controlestudio",$con);
      
   $sql=("SELECT * FROM materias WHERE cod_materia ='$t1'");
   $resultado=mysql_query($sql,$con);
   if(mysql_affected_rows()==0)
   {
    echo '<script>alert("La materia no existe.");</script>';
    
   } else {
   
     $row=mysql_fetch_array($resultado);
     $ci=$row['cod_materia'];
     $nombre=$row['descripcion'];
     $ucre=$row['ucredito'];
     $seme=$row['semestre'];
     mysql_free_result($resultado);
     mysql_close($con);
   
   }
 }
}

?>
ahora si me trae el contendo completo al momento de buscar (gracias a sus valioso aportes )

Pero aun no me elimina el registro acontinuacion detallo el codigo:

boton:
Código:
<input type="submit" name="cmdeli" id="cmdeli" value="Eliminar" onclick="avisarBorrado(<?= $ci ?>)" />
funcion validacion:
Código:
<script language="JavaScript">
function avisarBorrado(t1) {
 
 if (window.confirm("¿Estas realmente seguro de que deseas eliminar este registro?")) {
     
  
  location.href = "deletemateria.php?t1=" + t1;
  window.confirm("deletemateria.php?t1=" + t1);
  
 }
} 
</script>

documento de eliminacion:
<?php
function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "")
{
$theValue = (!get_magic_quotes_gpc()) ? addslashes($theValue) : $theValue;
switch ($theType) {
case "text":
$theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
break;
case "long":
case "int":
$theValue = ($theValue != "") ? intval($theValue) : "NULL";
break;
case "double":
$theValue = ($theValue != "") ? "'" . doubleval($theValue) . "'" : "NULL";
break;
case "date":
$theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
break;
case "defined":
$theValue = ($theValue != "") ? $theDefinedValue : $theNotDefinedValue;
break;
}
return $theValue;
}
if ((isset($_GET['t1'])) && ($_GET['t1'] != ""))
{
$con=mysql_connect("localhost","root","123");
mysql_select_db("controlestudio",$con);
$sql=sprintf("delete FROM materias WHERE cod_materia =%s",
GetSQLValueString($_GET['t1'], "text"));
$resultado=mysql_query($sql,$con);
if(mysql_affected_rows()!=0)
{
echo "registro eliminado";

}
//mysql_free_result($resultado);
mysql_close($con);


}


?>
  #12 (permalink)  
Antiguo 16/02/2010, 13:19
Avatar de hector2c  
Fecha de Ingreso: noviembre-2007
Ubicación: Perú - Tacna
Mensajes: 979
Antigüedad: 16 años, 5 meses
Puntos: 25
Pregunta Respuesta: guardar texto con espacio en un campo bd

en tu funcion avisarBorrado, modificala de este modo:

Código PHP:
<script language="JavaScript">
    function 
avisarBorrado(t1){
        
alert(t1);
        var 
respuesta confirm("Desea eliminar");
        if(
respuesta){
            
window.location "deletemateria.php?t1=" t1;
        }
    }
</script> 
puse un alert(t1), para que muestre si esta jalando el código adecuadamente, dime que mensaje sale?, sale el código del registro seleccionado???
__________________
blog: hector2c.wordpress.com
email: [email protected]
  #13 (permalink)  
Antiguo 16/02/2010, 15:23
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
Respuesta: guardar texto con espacio en un campo bd

Igual no funciona, ni siquiera me manda el alerta :(
  #14 (permalink)  
Antiguo 16/02/2010, 15:31
Avatar de hector2c  
Fecha de Ingreso: noviembre-2007
Ubicación: Perú - Tacna
Mensajes: 979
Antigüedad: 16 años, 5 meses
Puntos: 25
1. mmm, te aparecen el listado con los botones de eliminar???
2. muestra el código completo donde se lista...

hey!, respodne, responde, ya salgo a casa a descanzar XD!!!
__________________
blog: hector2c.wordpress.com
email: [email protected]

Última edición por GatorV; 16/02/2010 a las 16:35
  #15 (permalink)  
Antiguo 01/03/2010, 07:06
 
Fecha de Ingreso: abril-2006
Ubicación: Venezuela
Mensajes: 126
Antigüedad: 18 años
Puntos: 0
Respuesta: guardar texto con espacio en un campo bd

Gracias a todos, disculpen la demora en responder (no tenia internet). funciono perfectamente, borre la pagina y la cree nuevamente.

Etiquetas: bd, espacio, campos
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:55.