15. marts 2011 - 06:37
Der er
1 kommentar og
1 løsning
hente id ud af dtatabase
jeg skal have et id nummer ud af en database og så hvidt jeg kan se bør man bruge executescalar
men kan ikke rigtig få det til at virke,hvad gør jeg galt ?
myConnection.ConnectionString = "Data Source = xxx";
string strSQL2 = "SELECT `id` FROM `data11` Where email ='"+ Session["email"].ToString();
MySqlCommand sel = new MySqlCommand(strSQL2, myConnection);
myConnection.Open();
int id=sel.ExecuteScalar();
myConnection.Close();();
15. marts 2011 - 08:56
#1
Husk til en anden gang at fortælle hvilken fejlmeddelelse du får, så er det meget nemmere at hjælpe :)
Jeg tror dog at du får en feil, da ExecuteScalar returnerer et object, og du prøver at lægge denne ind i en int variabel uden at caste først.
Prøv at caste til int:
int id = (int)sel.ExecuteScalar();
I mange tilfælde vil en id fra en database være en long (dette kommer and på hvordan den er defineret i databasen), og da vil ovenstående fejle. Da kan du enten konvertere til en int:
int id = Convert.ToInt32(sel.ExecuteScalar());
eller caste til en long:
long id = (long)sel.ExecuteScalar();