Foros del Web » Programando para Internet » ASP Clásico »

Problema al insertar un registro

Estas en el tema de Problema al insertar un registro en el foro de ASP Clásico en Foros del Web. Hola, estoy intentando insertar un registro en una tabla cuyo nombre lo extraigo de una variable llamada "loc". El codigo que estoy utilizando es el ...
  #1 (permalink)  
Antiguo 18/09/2005, 08:40
Avatar de Mlora  
Fecha de Ingreso: agosto-2005
Mensajes: 18
Antigüedad: 19 años, 9 meses
Puntos: 0
Problema al insertar un registro

Hola, estoy intentando insertar un registro en una tabla cuyo nombre lo extraigo de una variable llamada "loc". El codigo que estoy utilizando es el siguiente:

<%
' *** Insert Record: set variables

If (CStr(Request("MM_insert")) = "fdossier") Then

MM_editConnection = MM_dossier_STRING
MM_editTable = "(" & Request.QueryString("loc") & ")"
MM_editRedirectUrl = "p_actualizar.asp"
MM_fieldsStr = "titulo|value|texto|value"
MM_columnsStr = "titulo|',none,''|texto|',none,''"

' create the MM_fields and MM_columns arrays
MM_fields = Split(MM_fieldsStr, "|")
MM_columns = Split(MM_columnsStr, "|")

' set the form values
For MM_i = LBound(MM_fields) To UBound(MM_fields) Step 2
MM_fields(MM_i+1) = CStr(Request.Form(MM_fields(MM_i)))
Next

' append the query string to the redirect URL
If (MM_editRedirectUrl <> "" And Request.QueryString <> "") Then
If (InStr(1, MM_editRedirectUrl, "?", vbTextCompare) = 0 And Request.QueryString <> "") Then
MM_editRedirectUrl = MM_editRedirectUrl & "?" & Request.QueryString
Else
MM_editRedirectUrl = MM_editRedirectUrl & "&" & Request.QueryString
End If
End If

End If
%>
<%
' *** Insert Record: construct a sql insert statement and execute it

Dim MM_tableValues
Dim MM_dbValues

If (CStr(Request("MM_insert")) <> "") Then

' create the sql insert statement
MM_tableValues = ""
MM_dbValues = ""
For MM_i = LBound(MM_fields) To UBound(MM_fields) Step 2
MM_formVal = MM_fields(MM_i+1)
MM_typeArray = Split(MM_columns(MM_i+1),",")
MM_delim = MM_typeArray(0)
If (MM_delim = "none") Then MM_delim = ""
MM_altVal = MM_typeArray(1)
If (MM_altVal = "none") Then MM_altVal = ""
MM_emptyVal = MM_typeArray(2)
If (MM_emptyVal = "none") Then MM_emptyVal = ""
If (MM_formVal = "") Then
MM_formVal = MM_emptyVal
Else
If (MM_altVal <> "") Then
MM_formVal = MM_altVal
ElseIf (MM_delim = "'") Then ' escape quotes
MM_formVal = "'" & Replace(MM_formVal,"'","''") & "'"
Else
MM_formVal = MM_delim + MM_formVal + MM_delim
End If
End If
If (MM_i <> LBound(MM_fields)) Then
MM_tableValues = MM_tableValues & ","
MM_dbValues = MM_dbValues & ","
End If
MM_tableValues = MM_tableValues & MM_columns(MM_i)
MM_dbValues = MM_dbValues & MM_formVal
Next
MM_editQuery = "insert into " & MM_editTable & " (" & MM_tableValues & ") values (" & MM_dbValues & ")"

If (Not MM_abortEdit) Then
' execute the insert
Set MM_editCmd = Server.CreateObject("ADODB.Command")
MM_editCmd.ActiveConnection = MM_editConnection
MM_editCmd.CommandText = MM_editQuery
MM_editCmd.Execute
MM_editCmd.ActiveConnection.Close

If (MM_editRedirectUrl <> "") Then
Response.Redirect(MM_editRedirectUrl)
End If
End If

End If
%>

Lo que estoy haciendo es sustituyendo el nombre de la tabla por (" & Request.QueryString("loc") & ") pero me da error al intentar insertar el registro.

Gracias.
  #2 (permalink)  
Antiguo 18/09/2005, 08:57
Avatar de Mlora  
Fecha de Ingreso: agosto-2005
Mensajes: 18
Antigüedad: 19 años, 9 meses
Puntos: 0
SOLUCIONADO. El error estaba en los parentesis (" & Request.QueryString("loc") & "), los he quitado y funciona.
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 15:49.