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


databas koppling i Classlibrary

Postades av 2004-01-26 16:29:24 - Anders Bengtsson, i forum asp.net generellt, Tråden har 1 Kommentarer och lästs av 434 personer

Jag har ett classlibrary där jag har massa klasser.
Just nu så varje gång jag kallar på en klass

class1 minclass = new class1();

så måste jag lägga en koppling till databasen där för att det ska funka.

public class1()
{
koppling till databasen.
}

efter ett tag kraschar mitt program och säger att den gjort timeout. Antagligen för att jag har för många databaskopplingar öppna till databasen. Men hur ska jag göra för att lägga en databas koppling som sen mina klasser kan hämta ifrån. Eller ännu bättre som min DataBasklass kan hämta från.


Svara

Sv: databas koppling i Classlibrary

Postades av 2004-01-27 13:15:40 - Mikael Sand

Käre isär skrivare :-)
Oki. Just att din applikation får timeout behöver ju inte bero på just databasen om du inte får ett sådant fel, vilket jag antar att du har koll på. Om så är ett faktum så kan jag nästan garantera att din kod inte kopplar ner ordentligt då jag samtidigt nästan är säker på att du antingen kör en MSDE eller Access och då har du begränsad mängd kopplingar.

Upplägget kring hur du ska skriva databashantering m m i en asp.net-applikation kostar 20 000 att lära sig. Det tar tre dagar men du får ett litet diplom där det kanske står "Johansson & Tandkött" eller "Jonson Education".
Jag kör en snabb genomgång på databasnivå gratis och här får gärna de två hjärnorna bakom asp.net upphöjt till två vara med och rätta eller fylla i luckor.

Grundtanken är alltid att aldrig ha en koppling igång mer än du verkligen behöver. Om du inte kör transaktioner så behöver du kopplingen i EN rad och inget annat.
<code>
' annan kod
myDataAdapter.Fill(ds)
' stäng kopplingen
</code>
Om du bygger saker smart, med arv och annat ska du heller inte behöva returnera kopplingar mellan olika klasser och därigenom heller inte gör kopplingen till något annat än en variabel deklarerad som private.
Sen har vi det faktum att ibland kraschar saker. Då lägger du kopplingens stängande under Finally i ett inneslutande try...catch-block.

Denna kodstruktur återfinns s a s längst ner i din klasstruktur. Jag brukar kalla den för "DataModifier" eller "DBEngine" eller liknande.
Denna klass instanserar du sedan i någon av alla dina klasser för hantering av data. De ligger ett snäpp upp och kallas i allmänhet för något i stil med "DataAccessComponents". Deras uppgift är att skyffla data och omforma den för att den ska passa i din databas.
Ovan dessa ligger en rad klasser som brukar kallas "Affärslogik". Lämpliga namn kan t ex vara "User", eller "Games". Alltså benämda efter systemets entiteter, snarare än just tabeller. Varje sådan komponent har kontakt med noll till flera olika instanser av dina DataAccessComponents.

Det viktiga i strukturen är att inget lager behöver veta vad det andra gör. Din klass t ex kallad "User" har en funktion som heter GetByID och som tar emot en integer och returnerar ett dataset (eller annan form av datacontainer). Mer behöver inte interfacet bry sig om. Samma förhållande gäller nedåt och sedemera också uppåt.

//Mikael Sand


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 602
27 953
271 705
651
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