Avatar billede Slettet bruger
07. maj 2006 - 20:01 Der er 6 kommentarer og
1 løsning

Database hjælp..

Hvorfor virker den her kode ikke?:S

----------------------------------------------------------------

<html>
<title>Indsætte data i databasen</title>
<head>
</head>
<body>
<%
Set Conn = Server.CreateObject("ADODB.Connection")
DSN = "DRIVER={Microsoft Access Driver (*.mdb)}; "
DSN = DSN & "DBQ=" & Server.MapPath("/db/database.mdb")
Conn.Open DSN

strSQL = "Insert into personer (Fornavn) values('" & Request.Form("Fornavn") & "')"

Conn.Execute(strSQL)

Conn.Close
Set Conn = Nothing
%>
<form action="indsat.asp" method="post">
<input type="text" name="Fornavn">
<input type="submit" value="Gem">
</form>

<h1>Databasen er opdateret!</h1>
</body>
</html>

-----------------------------------------------------------------
Avatar billede eagleeye Praktikant
07. maj 2006 - 20:08 #1
Nu kan der være mange ting som gør den ikke virker så det ville hjælp hvis du skrev hvilken fejl du får eller beskriver fejlen.


Men en ting når kodn som gemmer ligger i samme fil som formen skal man tjekke på om der er post'ed data til siden inden man indsætter i database så:

<%
Set Conn = Server.CreateObject("ADODB.Connection")
DSN = "DRIVER={Microsoft Access Driver (*.mdb)}; "
DSN = DSN & "DBQ=" & Server.MapPath("/db/database.mdb")
Conn.Open DSN

strSQL = "Insert into personer (Fornavn) values('" & Request.Form("Fornavn") & "')"

Conn.Execute(strSQL)

Conn.Close
Set Conn = Nothing
%>




Bliver til dettte med en if sætning omkring:


<%
if Request.ServerVariables("SCRIPT_NAME") = "POST" then
  Set Conn = Server.CreateObject("ADODB.Connection")
  DSN = "DRIVER={Microsoft Access Driver (*.mdb)}; "
  DSN = DSN & "DBQ=" & Server.MapPath("/db/database.mdb")
  Conn.Open DSN

  strSQL = "Insert into personer (Fornavn) values('" & Request.Form("Fornavn") & "')"

  Conn.Execute(strSQL)

  Conn.Close
  Set Conn = Nothing
end if
%>
Avatar billede thesurfer Nybegynder
07. maj 2006 - 20:13 #2
eagleeye> Request.ServerVariables("SCRIPT_NAME") = "POST" ?
Mener du ikke Request.Servervariables("REQUEST_METHOD") = "POST" ..?

"SCRIPT_NAME" giver vel kun "/rod/mappe/side.asp"..?

/theSurfer
Avatar billede thesurfer Nybegynder
07. maj 2006 - 20:15 #3
..og det ville nok være en god ide, at replace her:

values('" & replace(Request.Form("Fornavn"), "'", "''") & "')"

/theSurfer
Avatar billede eagleeye Praktikant
07. maj 2006 - 20:16 #4
doh.. jo det skal være "REQUEST_METHOD"  ;)
Avatar billede Slettet bruger
07. maj 2006 - 20:20 #5
Hvordan ser hele koden ud?
Avatar billede Slettet bruger
07. maj 2006 - 20:22 #6
Virker:P
Avatar billede eagleeye Praktikant
07. maj 2006 - 20:23 #7
ok ;)
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester