Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


SQL-fråga - två till en

Postades av 2006-03-05 11:56:28 - Nina Ringbom, i forum asp - allmänt, Tråden har 12 Kommentarer och lästs av 582 personer

Hej
Jag undrar om man kan "sätta ihop" dom här två till en, eftersom det är samma databas (klick.mdb) så tycker jag det borde gå..? Men hur ser det ut i sånna fall?

<%
Set Connect = Server.CreateObject("ADODB.Connection")
Connect.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("klick.mdb")
' Uppdaterar antalet klick
strSQL = "UPDATE saba SET klick = klick + 1 WHERE id = " & Request.Querystring("id")
Connect.Execute(strSQL)
Connect.Close: Set Connect = Nothing
%>

och

<%
Set Connect = Server.CreateObject("ADODB.Connection")
Connect.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("klick.mdb")
' Uppdaterar antalet klick
strSQL = "UPDATE saba SET klicktotalt = klicktotalt + 1 WHERE id = " & Request.Querystring("id")
Connect.Execute(strSQL)
Connect.Close: Set Connect = Nothing
%>

/Nina


Svara

Sv: SQL-fråga - två till en

Postades av 2006-03-05 12:45:58 - Mikael Jönsson

Tror detta fungerar:

<code>
<%
Set Connect = Server.CreateObject("ADODB.Connection")
Connect.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("klick.mdb")
' Uppdaterar antalet klick
strSQL = "UPDATE saba SET klick = klick + 1, klicktotalt = klicktotalt + 1 WHERE id = " & Request.Querystring("id")
Connect.Execute(strSQL)
Connect.Close: Set Connect = Nothing
%>
</code>

/Micke


Svara

Sv:SQL-fråga - två till en

Postades av 2006-03-05 13:12:24 - Nina Ringbom

tack! jättesnällt, det funkade klockrent!

kan man även sätta ihop två sånna här:

<%
Set Connect = Server.CreateObject("ADODB.Connection")
Connect.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("handelser.mdb")
' Uppdaterar antalet klick
strSQL = "UPDATE handelse SET klick = klick + 1 WHERE id = " & Request.Querystring("id")
Connect.Execute(strSQL)
Connect.Close: Set Connect = Nothing

Set Connect = Server.CreateObject("ADODB.Connection")
Set RecSet = Server.CreateObject("ADODB.Recordset")
Connect.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("handelser.mdb")
strSQL = "SELECT * From handelse WHERE id = " & Request.QueryString("id")
RecSet.Open strSQL, Connect
%>

mvh Nina


Svara

Sv: SQL-fråga - två till en

Postades av 2006-03-05 13:44:03 - Anna-Karin Söderberg

Connect.Execute(strSQL) är det som kör din Update, där vill du inte ha tillbaka något svar.
RecSet.Open strSQL, Connect, är det som kör din selectsats och du får svaret till RecSet.

Så du kan alltså inte slå ihop dessa två.


//Anna-Karin


Svara

Sv:SQL-fråga - två till en

Postades av 2006-03-05 14:02:48 - Nina Ringbom

OK tack då vet jag !

mvh Nina


Svara

Sv: SQL-fråga - två till en

Postades av 2006-03-05 23:44:57 - Andreas Hillqvist

Du behöver inte öppna anslutningen två gånger. Utan kan skriva:

<%
Set Connect = Server.CreateObject("ADODB.Connection")
Connect.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("handelser.mdb")
' Uppdaterar antalet klick
strSQL = "UPDATE handelse SET klick = klick + 1 WHERE id = " & Request.Querystring("id")
Connect.Execute(strSQL)

Set RecSet = Server.CreateObject("ADODB.Recordset")
strSQL = "SELECT * From handelse WHERE id = " & Request.QueryString("id")
RecSet.Open strSQL, Connect


RecSet.Close: Set RecSet = Nothing
Connect.Close: Set Connect = Nothing

%>

Eventuellt kan du öppna recordsetet redigerbart, Låsa applikationen göra uppdateringen och låsa upp.
Låsa för att hindra att race condition uppstår. Du får testa vilket av tillvägagångssätten som är effektivast.

Dessutom bör du läsa dig in på SQL inject. Då dina kod är mottaglig mot dessa angrepp.
JAg rekomenderar att lösa detta genom att använda ett command objekt med paramterar.


Svara

Sv:SQL-fråga - två till en

Postades av 2006-03-06 19:10:46 - Nina Ringbom

hej
det där sista förstod jag inte "ett command objekt med parameter" ?
har du ett enkelt tips så tar jag gärna emot det ;-)

/nina


Svara

Sv: SQL-fråga - två till en

Postades av 2006-03-07 08:49:08 - Andreas Hillqvist

Koden för att använda ett command skulle se ut så här:

<%
Dim con 
Dim cmd

Const adInteger = 3
Const adParamInput = 1
Const adExecuteNoRecords = 128

    Set con = CreateObject("ADODB.Connection")
    con.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("handelser.mdb")
    
    Set cmd = CreateObject("ADODB.Command")
    Set cmd.ActiveConnection = con
    cmd.CommandText = "UPDATE handelse SET klick = klick + 1" & vbCrLf & _
                      "WHERE id = @id"
                      
    cmd.Parameters.Append cmd.CreateParameter("@id", adInteger, adParamInput, , Request.Querystring("id"))
    cmd.Execute , , adExecuteNoRecords
                      
    Set cmd.ActiveConnection = Nothing
    Set cmd = Nothing
    
    con.Close
    Set con = Nothing
%>


Din site lider dessutom av en annan alvarlig säkerhets brist. Din databas ligger i en mapp tillgänglig från nättet. Därför kan vem som helst ladda ner den.
Du bör lägga databaser i en katalog som inte är tillgänglig från nätet men där asp kontot har läs och skrivrättigheter.


Svara

Sv:SQL-fråga - två till en

Postades av 2006-03-07 21:39:09 - Nina Ringbom

Hej
hur menar du när du skriver "inte är tillgänglig från nätet?"
en underkatalog till där jag har mina andra filer? Men kan inte vem som helst komma åt den också?
hur sätter man så att aspkontot har läs och skrivrättigheter till katalogen?


Svara

Sv: SQL-fråga - två till en

Postades av 2006-03-07 22:00:43 - Andreas Hillqvist

För att den inte skalla vara tillgänglig från nätet är det ofta bättre att inte lägga den under WWWROOT katalogen alls. Utan skapa en helt egen katalog. I utforskaren kan man sedan tilldela ASP kontot rättigheter. Kontot vilket ASP motorn kör under brukar vara IUSER_<Datornamn>. T.ex. IUSER_LAPTOP om min dator Heter LAPTOP.


Svara

Sv:SQL-fråga - två till en

Postades av 2006-03-07 22:39:54 - Mikael Kristiansson

Andreas, skulle du vilja förklara vad denna gör i sina parametrar och hur den samspelar med CommandText vid Update-körningen?

cmd.Parameters.Append cmd.CreateParameter("@id", adInteger, adParamInput, , Request.Querystring("id"))


Mvh Micke


Svara

Sv: SQL-fråga - två till en

Postades av 2006-03-08 10:42:15 - Andreas Hillqvist

Normalt förklaras dessa i dokumentationen. En programmerar gör sig vän med dokumentationen.

Konstanter är deklarerade i adovbs.inc så man kan välja att inkludera denna eller lägga in en meta tag för ADO's typlibary.

Förstaparametern: Namn på paramtern om platshållaren för parametern är anonym. Det vill säga att det är ett frågetecken har inte namnet betydelse utan dess matchas genom ordning av frågetecknet i frågan samt ordningen av parametern i paramer samlingen.

Andraparametern: Datatyp för parametern. adInteger för heltal och adVarChar för strängar är det två vanligaste.

Tredjeparamtern: Riktning på paramtern. Är det för input till frågan, output eller båda.

Fjärdeparamtern: Storlek på fältet. Bara nödvändigt för t.ex. stränga och sånt.

Femteparamtern: Initialvärde för paramtern.

Om man har en loop så kan man tjäna på att använda ett command.


Dim I 
Dim con 
Dim cmd
Dim UserName
Dim UserPassword

Const adInteger = 3
Const adVarChar = 200 
Const adParamInput = 1
Const adExecuteNoRecords = 128

    Set con = CreateObject("ADODB.Connection")
    con.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source= "& server.MapPath("handelser.mdb")
    
    Set cmd = CreateObject("ADODB.Command")
    Set cmd.ActiveConnection = con
    cmd.CommandText = "INSERT INTO Users (UserName, UserPassword)" & vbCrLf & _
                      "VALUE (@Name, @Password)"
                      

    UserName = cmd.CreateParameter("@Name", adVarChar, adParamInput, 20)
    cmd.Parameters.Append UserName

    UserPassword = cmd.CreateParameter("@Password", adVarChar, adParamInput, 20)
    cmd.Parameters.Append UserPassword

    cmd.Prepered = True 

    For I = 1 To Request.Form("Count")
        UserName.Value = Request.Form("UserName" & I)
        UserPassword.Value = Request.Form("UserPassword" & I)
        cmd.Execute , , adExecuteNoRecords
    Next
                      
    Set cmd.ActiveConnection = Nothing
    Set cmd = Nothing
    
    con.Close
    Set con = Nothing

Detta borde ge bättre prestanda.


Svara

Sv:SQL-fråga - två till en

Postades av 2006-03-09 06:05:13 - Mikael Kristiansson

Stort Tack för din förklaring!
Får kolla upp det mer när där finns tid till det.

Återkommer kanske i en annan tråd om jag undrar något mer om detta.

Micke


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 600
27 953
271 705
4 058
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies