Foros del Web » Programando para Internet » PHP »

Problema para insertar registros en SQL Server 2000 desde PHP

Estas en el tema de Problema para insertar registros en SQL Server 2000 desde PHP en el foro de PHP en Foros del Web. Hola a todos, este es mi primer post y tengo un problema, lo que pasa esq estoy haciendo un formulario en html que envía los ...
  #1 (permalink)  
Antiguo 07/01/2011, 18:28
 
Fecha de Ingreso: enero-2011
Mensajes: 13
Antigüedad: 13 años, 3 meses
Puntos: 0
Pregunta Problema para insertar registros en SQL Server 2000 desde PHP

Hola a todos, este es mi primer post y tengo un problema, lo que pasa esq estoy haciendo un formulario en html que envía los datos capturados a un PHP y en el php está lo siguiente:

Código PHP:
<?php
    error_reporting
(E_ALL);
    
ini_set("display_errors"1);
    
    echo (
"A ver si se ve esto<br />\r\n");

//Conexión a SQL Server
    
$conectaMSSQL odbc_connect("peginaCICSA","salitas2","accesoremoto") or die('Algo pas&oacute; y no hubo conexi&oacute; a la Base de Datos');

    
//Inserta el registro en la tabla "altaWifi" de la base de datos "WEB".
    
$inserta='INSERT INTO altaWiFi (Usuario,Nombre,Facultad,Carrera,Clave_RPE,MAC,Antivirus,Dispositivo) VALUES ('.$_POST["Usuario"].','.$_POST["nombre"].','.$_POST["facultad"].','.$_POST["carrera"].','.$_POST["clave_rpe"].','.$_POST["mac"].','.$_POST["antivirus"].','.$_POST["dispositivo"].' )';

    
odbc_exec($conectaMSSQL,$inserta) or die("<br />No se insertaron los datos");
    echo(
"<h1>Se ha guardado correctamente</h1>");
        
    
odbc_close($conectaMSSQL);
    
?>
    <a onclick="history.back()"><h2>Regresar</h2></a>
La tabla antes del campo "Usuario" tiene los campos "Registro" q es un número consecutivo y "fechaAlta" q es un timestamp.

El resultado que arroja es lo siguiente:

Código:
A ver si se ve esto
Warning: odbc_exec(): SQL error: [Microsoft][ODBC SQL Server Driver][SQL Server]El nombre 'Ruperto' no es v�lido en este contexto. S�lo se permiten constantes, expresiones o variables. No se permiten nombres de columna., SQL state 37000 in SQLExecDirect in C:\Inetpub\wwwroot\PAG CICSA\altaWiFi.php on line 49 
No se insertaron los datos
  #2 (permalink)  
Antiguo 07/01/2011, 18:36
Avatar de maycolalvarez
Colaborador
 
Fecha de Ingreso: julio-2008
Ubicación: Caracas
Mensajes: 12.120
Antigüedad: 15 años, 8 meses
Puntos: 1532
Respuesta: Problema para insertar registros en SQL Server 2000 desde PHP

puede deberse a que no especificas las cadenas internas del SQL cn comillas simples, por eso es preferible que uses comillas dobles para php en este caso:

$sql = "insert into tabla (n-campos) values ('cadena SQL con comillas')";
__________________
¡Por favor!: usa el highlight para mostrar código
El que busca, encuentra...
  #3 (permalink)  
Antiguo 07/01/2011, 19:09
 
Fecha de Ingreso: enero-2011
Mensajes: 13
Antigüedad: 13 años, 3 meses
Puntos: 0
Respuesta: Problema para insertar registros en SQL Server 2000 desde PHP

Cita:
Iniciado por maycolalvarez Ver Mensaje
puede deberse a que no especificas las cadenas internas del SQL cn comillas simples, por eso es preferible que uses comillas dobles para php en este caso:

$sql = "insert into tabla (n-campos) values ('cadena SQL con comillas')";
Pues ahora cambié esa cadena de esta manera:

Código PHP:
$inserta="INSERT INTO [altaWiFi] (Usuario,Nombre,Facultad,Carrera,Clave_RPE,MAC,Antivirus,Dispositivo) VALUES ('$_POST[Usuario]','$_POST[nombre]','$_POST[facultad]','$_POST[carrera]','$_POST[clave_rpe]','$_POST[mac]','$_POST[antivirus]','$_POST[dispositivo]')"
Y me arrojo ahora este error:

Código:
Warning: odbc_exec(): SQL error: [Microsoft][ODBC SQL Server Driver][SQL Server]Los datos de cadena o binarios se truncar�an., SQL state 22001 in SQLExecDirect in C:\Inetpub\wwwroot\PAG CICSA\altaWiFi.php on line 52
  #4 (permalink)  
Antiguo 10/01/2011, 09:47
 
Fecha de Ingreso: enero-2011
Mensajes: 13
Antigüedad: 13 años, 3 meses
Puntos: 0
Respuesta: Problema para insertar registros en SQL Server 2000 desde PHP

ya no me sale el error de que "El nombre 'X' no es válido en este contexto."

cambié la cadena a la siguiente manera.

Código PHP:
$inserta="INSERT INTO [altaWiFi] (fechaAlta,tipo_Usuario,Nombre,Facultad,Carrera,Clave_RPE,MAC,Antivirus,Dispositivo) VALUES (getdate(),'" $_POST['Usuario'] . "','".$_POST['nombre']."','".$_POST['facultad']."','".$_POST['carrera']."','".$_POST['clave_rpe']."','".$_POST['mac']."','".$_POST['antivirus']."','".$_POST['dispositivo']."' )"
pero ahora me sale el siguiente error

Código HTML:
Warning: odbc_exec(): SQL error: [Microsoft][ODBC SQL Server Driver][SQL Server]Los datos de cadena o binarios se truncar�an., SQL state 22001 in SQLExecDirect in C:\Inetpub\wwwroot\PAG CICSA\altaWiFi.php on line 49

  #5 (permalink)  
Antiguo 24/01/2011, 13:41
 
Fecha de Ingreso: enero-2011
Mensajes: 13
Antigüedad: 13 años, 3 meses
Puntos: 0
Respuesta: Problema para insertar registros en SQL Server 2000 desde PHP

Ya jaló

así es como quedó ese código

Código PHP:
$inserta="INSERT INTO [altaWiFi] (fechaAlta,tipo_Usuario,Nombre,Facultad,Carrera,Clave_RPE,MAC,Antivirus,Dispositivo) VALUES (getdate(),'".$_POST['Usuario']."','".$_POST['nombre']."','".$_POST['facultad']."','".$_POST['carrera']."','".$_POST['clave_rpe']."','".$_POST['mac']."','".$_POST['antivirus']."','".$_POST['dispositivo']."' )"

Etiquetas: registros, server, 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 08:19.