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


Logg i databas - komplicerad

Postades av 2006-01-09 00:21:15 - André Claesson, i forum asp.net generellt, Tråden har 4 Kommentarer och lästs av 474 personer

Jag har en sida där användaren kan välja ett antal filer som han/hon vill ladda ner.
Dessa filer packas i en zip fil som sedan kan laddas ner.

Detta fungerar bra, även om man väljer ca 10 000 filer. Tar ca 1-2 minuter.

Problemet jag har att detta måste loggas i databasen. Varje fil har en post i tabellen Files och som är kopplad till dess ägare (i tabellen Users). Den ägaren ska kunna se hur många gånger hans/hennes fil(er) har blivit nerladdad(e).
Just nu har jag en foreach-loop som (10 000 grr) läser fältet download i tabellen Files på den filen och plusar på 1 och sen uppdaterar detta. Trots 20 000 sql-kommando mot en access-databas fungerar det faktiskt. Dock tar det minst 3 gånger så lång tid när loggningen är på (och ibland misslyckas det).

Har ni någon smartare lösning på problemet? Kan det gå snabbare om man skriver 10 000 Insert till en separat tabell. Denna kommer i så fall få ca 1 000 000 poster efter några månader.
Fördelen med det, och något jag skulle önska, är att varje användare då även kunde se Vem som laddad ner hans/hennes fil.

Är detta en för stor uppgift för en databas? Hur stor skillnad kan det bli med ms sql?

Jag använder C#.

Lite kod:

foreach (string file in files) //Vilka filer det gäller fås från en SQL-sats
{
	string SQLCheck = @"	SELECT downloaded
			FROM Files
			WHERE url = @file;";

	string SQLAdd = @"	UPDATE Files
			SET downloaded = @downloaded
			WHERE url = @file;";

	OleDbCommand comCheck = new OleDbCommand(SQLCheck, oleDbConn);
	comCheck.Parameters.Add("file", file);
	int downloaded = (int)comCheck.ExecuteScalar();

	downloaded++;

	OleDbCommand comAdd = new OleDbCommand(SQLAdd, oleDbConn);
	comAdd.Parameters.Add("downloaded", downloaded);
	comAdd.Parameters.Add("file", file);
	comAdd.ExecuteNonQuery();
}


Antalet uppladdare (användare som har filer) är ca 5 000. Nerladdare är tvåsiffrigt.

/andrec


Svara

Sv: Logg i databas - komplicerad

Postades av 2006-01-09 08:17:37 - Martin Adrian

Kan du inte göra

"Update Files Set downloaded = downloaded + 1 WHERE url In (SELECT ...)"


Svara

Sv:Logg i databas - komplicerad

Postades av 2006-01-09 10:24:37 - Ola Lindfeldt

Ovanstående tips är bra, samt se till att fältet url är indexerat.

.Net koden kan också snabbas upp en del.

Det är dumt att skapa nya OleDb och String objekt i varje varv i snurran.
Det räcker ju att du sätter param.Value och exekverar.
Det bör snabba upp lite när du gör upp emot 10.000 iterationer.


Svara

Sv: Logg i databas - komplicerad

Postades av 2006-01-09 11:06:54 - Marcus Gus

det Martin menar kan nog sammanfatts i detta... En enda sqlsats som kommer att köras.

string download;
foreach (string file in files) //Vilka filer det gäller fås från en SQL-sats
{
 download += file;
}

string SQLAdd = @"Update Files Set downloaded = downloaded + 1 WHERE url In [" + download + "];";


OleDbCommand comAdd = new OleDbCommand(SQLAdd, oleDbConn);
comAdd.Parameters.Add("file", file);
comAdd.ExecuteNonQuery();


Svara

Sv:Logg i databas - komplicerad

Postades av 2006-01-11 04:07:32 - André Claesson

Tack det funkar, efter lite modifieringar!

/andrec


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 604
27 953
271 705
5 962
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