Avatar billede stauer Nybegynder
04. september 2002 - 17:46 Der er 10 kommentarer og
1 løsning

syntax error når jeg skal update en tabel

Hejsa

Jeg får følgende fejl når jeg prøver at opdatere et recordset.

"Syntax error in UPDATE statement"

Jeg tror muligvis det er fordi nogle at mine felter i dB'en er defineret til Tal istedet for teskt. Men hvordan tager man forbehold for det - Eller er der en anden fejl i det jeg har lavet?

id = Request.Form("id")
kategori = Request.Form("kategori")
titel = SQLSafe (Request.Form("titel"))
forfatter = SQLSafe (Request.Form("forfatter"))
forlag = SQLSafe (Request.Form("forlag"))
udaar = Request.Form("udaar")
pris = SQLSafe (Request.Form("pris"))
indhold = SQLSafe (Request.Form("indhold"))

strSQL = "UPDATE boger SET (kategori, titel, forfatter, forlag, udaar, pris, indhold) VALUES ("
strSQL = strSQL & "'" & kategori &"', "
strSQL = strSQL & "'" & titel &"', "
strSQL = strSQL & "'" & forfatter &"', "
strSQL = strSQL & "'" & forlag &"', "
strSQL = strSQL & "'" & udaar &"', "
strSQL = strSQL & "'" & pris &"', "
strSQL = strSQL & "'" & indhold & "' "
strSQL = strSQL & ");"
Avatar billede stauer Nybegynder
04. september 2002 - 17:49 #1
strSQL = strSQL & "); Where id = "&id"

hvordan er syntaksen hvis jeg vil indsætte linien ovenfor?
Avatar billede tmceu Praktikant
04. september 2002 - 17:50 #2
Den korrekt syntax for UPDATE er:

UPDATE MinTabel SET Felt1 = 123, Felt2 = 'ABC' WHERE MinID = 1

Du har blandet INSERT INTO og UPDATE lidt sammen :-)
Avatar billede eagleeye Praktikant
04. september 2002 - 17:51 #3
Du har blandet INSERT og UPDATE sammen....

UPDATE skal havde dette format :

UPDATE tabel SET kolonne1 = data, kolonne2 = data, kolonne3 = data WHERE id = xxx
Avatar billede a1a1 Novice
04. september 2002 - 17:51 #4
strSQL = "UPDATE boger SET (kategori, titel, forfatter, forlag, udaar, pris, indhold) VALUES ("
strSQL = strSQL & "'" & kategori &"', "
strSQL = strSQL & "'" & titel &"', "
strSQL = strSQL & "'" & forfatter &"', "
strSQL = strSQL & "'" & forlag &"', "
strSQL = strSQL & "'" & udaar &"', "
strSQL = strSQL & "'" & pris &"', "
strSQL = strSQL & "'" & indhold & "' "
strSQL = strSQL & ") WHERE ID =" & id & ";"
Avatar billede a1a1 Novice
04. september 2002 - 17:51 #5
ja eagleeye det havde jeg da ikke set :))))
Avatar billede tmceu Praktikant
04. september 2002 - 17:51 #6
Hvis du faktisk forsøger at indsætte en række:

INSERT INTO MinTabel (Felt1, Felt2) VALUES(123, 'ABC')
Avatar billede eagleeye Praktikant
04. september 2002 - 17:54 #7
Jeg kan anbefale denne side http://www.w3schools.com/sql/default.asp
Der kan du hurtigt se hvordan syntaxen er for både INSERT og UPDATE samt andre SQL kommandoer.
Avatar billede stauer Nybegynder
04. september 2002 - 17:55 #8
er a1 forslag så forkert?
Avatar billede eagleeye Praktikant
04. september 2002 - 18:00 #9
Ja hvis det er en opdate du vil lave, du skal lave den i stil med:


strSQL = "UPDATE boger SET kategori = '" & kategori & "', titel = '" & titel &"', forfatter = '" & forfatter &"', forlag = '" & forlag &"', udaar = '" & udaar &"', pris = '" & pris &"', indhold = '" & indhold & "'"
strSQL = strSQL & " WHERE ID =" & id & ";"
Avatar billede stauer Nybegynder
04. september 2002 - 18:08 #10
muchas gracias.. jeg har ofte problemer med at finde ud af hvordan man skal sætte de forskellige tegn ' og " .. kender i et sted på nettet  hvor man kan lære mere om det?
Avatar billede eagleeye Praktikant
04. september 2002 - 18:12 #11
Nej jeg har ikke lige noget godt link prøv evt at kigge på http://www.w3schools.com der er også nogle sider omkring ASP.

" bruges til at starte og stoppe strenge i ASP
' bruges til at starte og stoppe strenge i SQL sætninger..

Og når man så bygger SQL streng op med ASP så blvier det lidt forvirne i starten med både ' og ". Det er måske lettere at forstå hvad det skal blive til med SQL'en:

Eks hvis man har dette
kategori = "KAT2"
id = 2434
strSQL = "UPDATE boger SET kategori = '" & kategori & "' WHERE ID = " & id

Så bliver strSQL til:
UPDATE boger SET kategori = 'KAT2' WHERE ID = 2434
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

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