Avatar billede morf4r Nybegynder
09. december 2006 - 20:10 Der er 6 kommentarer og
1 løsning

database connection

Jeg har en metode: public Medarbejder medarbejderHent(int medarbejderID)

Her åbner jeg en ny connection for at kunne få navn,adresse osv ud fra en given medarbejder.


så har jeg også en public Arraylist medarbejderHentKompetencer(int medarbejderID)

Udsnit af kode:

            SqlCommand cmd = new SqlCommand(sql, conn);
            conn.Open();        // åbner ny
            SqlDataReader reader = cmd.ExecuteReader();

            try
            {
                while (reader.Read())
                {
                    Medarbejder m;
                    Kompetence k;
                    m = medarbejderHent(medarbejderID);
                          // kalder metoden som også laver en ny


Her kommer der så selvfølgelig fejlen, at jeg allerede har en åben connection.
Jeg har løst det ved at bruge conn2.Open() istedet for conn.Open() i min medarbejderHent metode, men ved at man kan bruge conn.Open(). Hjælp :D
Avatar billede arne_v Ekspert
09. december 2006 - 20:17 #1
generelt kan du ikke lave 2 ting samtidigt på samme connection (jeg mener
at der blev tilføjet noget snedigt til SQLServer provideren i .NET 2.0, men
ikke generelt)

så enten bruger du 2 connections eller så henter du al data med en enkelt query
med en join
Avatar billede dr_chaos Nybegynder
09. december 2006 - 20:18 #2
Brug noget i denne stil (pseudo kode med stavefejl.)
            SqlCommand cmd = new SqlCommand(sql, conn);
if(Cmd.Connection.Connectionstate != Connectionstate.open)
  conn.Open();
            SqlDataReader reader = cmd.ExecuteReader();
Avatar billede morf4r Nybegynder
09. december 2006 - 20:41 #3
Okay, så der er altså ikke noget underligt i at have flere connections?
Har ikke programmeret i særlig lang tid, så har indtil videre kun brugt 1 connection til alt i mine programmer.
Avatar billede morf4r Nybegynder
09. december 2006 - 20:42 #4
Tænker på at jeg bruger "conn" overalt i mit progam, men så til det her vil jeg pludselig bruge "conn2" én gang, og det er det. Virker underligt synes jeg =)
Avatar billede arne_v Ekspert
09. december 2006 - 20:45 #5
det er ikke variabel navnet som betyder noget

du kan godt have 2 connections som begge hedder conn eller en conn og en conn2 som
er samme connection
Avatar billede morf4r Nybegynder
09. december 2006 - 20:52 #6
Okay, tror bare jeg bruger conn2 som er samme connection, irriterer mig bare at jeg bliver nød til det, synes det virker så tomt at bruge conn2 til _en_ ting løbet af hele programmet.
Nåmen smid et svar arne :)
Avatar billede arne_v Ekspert
09. december 2006 - 23:33 #7
svar
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
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

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