Avatar billede Driton Seniormester
26. januar 2012 - 01:32 Der er 3 kommentarer og
1 løsning

cmd.ExecuteScalar()

Goddag, jeg har et lille problem :D,

Når jeg kører den stykke kode får jeg en tilsendt 0, istedet for den id som bliver oprettet, er der nogle som har en ide hvor fejlen ligger?

cmd.CommandText = ("insert into Godkendelse (Godkendelse) values (@Godkendelse)");

        cmd.Parameters.Add("@Godkendelse","0");
        Conn.Open();
        int IdReturnedGodkendelse = Convert.ToInt32(cmd.ExecuteScalar());
        Conn.Close();
Avatar billede arne_v Ekspert
26. januar 2012 - 01:50 #1
Hvorfor i al verden skulle den returnere den genererede id??

ExecuteScalar er til at udfoere SELECT med.

Du bruger ExecuteNonQuery til INSERT.
Avatar billede arne_v Ekspert
26. januar 2012 - 01:52 #2
De mest oplagte muligheder er:

1)

lave en SELECT SCOPE_IDENTITY() efter INSERT for at hente id

2)

undlad at hente den id og bare brug SCOPE_IDENTITY() i efterfoelgende SQL saetninger som skal bruge den

3)

lave en SP som laver baade INSERT og SELECT SCOPE_IDENTITY()
Avatar billede Driton Seniormester
26. januar 2012 - 02:37 #3
Tak det hjælp
Avatar billede arne_v Ekspert
26. januar 2012 - 03:06 #4
saa smider jeg et 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