Avatar billede beorndesign Nybegynder
16. januar 2005 - 22:09 Der er 3 kommentarer og
1 løsning

Microsoft.Data.Odbc.OdbcException

Hvad er det, som er forkert? Jeg får følgende fejl:

ERROR [IM002] [Microsoft][ODBC Driver Manager] Data source name not found and no default driver specified
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: Microsoft.Data.Odbc.OdbcException: ERROR [IM002] [Microsoft][ODBC Driver Manager] Data source name not found and no default driver specified

Source Error:

Line 6:  void Page_Load(object sender, System.EventArgs e){
Line 7:    OdbcConnection objCon = new OdbcConnection(ConfigurationSettings.AppSettings["connString"]);
Line 8:    objCon.Open();
Line 9:    string strSQL = "SELECT * FROM Guestbook";
Line 10:  OdbcCommand objCmd = new OdbcCommand(strSQL, objCon);

----- kode.aspx ----

<% @ Page Language="c#" %>
<% @ Import Namespace="System.Data" %>
<% @ Import Namespace="Microsoft.Data.Odbc" %>

<script language="c#" runat="server">
void Page_Load(object sender, System.EventArgs e){
  OdbcConnection objCon = new OdbcConnection(ConfigurationSettings.AppSettings["connString"]);
  objCon.Open();
  string strSQL = "SELECT * FROM Guestbook";
  OdbcCommand objCmd = new OdbcCommand(strSQL, objCon);

  OdbcDataReader oDataReader = objCmd.ExecuteReader(CommandBehavior.CloseConnection);
  MyDataGrid.DataSource = oDataReader;
  MyDataGrid.DataBind();
}
</script>

<html>
  <body>
  <ASP:DataGrid id="MyDataGrid" runat="server"  />
</body>
</html>

---- web.config ----
<configuration>
    <appSettings>
        <add key="connString" value="driver={MySQL};server=webhotel.com;database=db;uid=uid_dk;pwd=pwd;OPTION=16386" />
    </appSettings>
    <system.web>
      <customErrors mode="Off"/>
      <compilation debug="true"/>
    </system.web>
</configuration>
Avatar billede arne_v Ekspert
16. januar 2005 - 22:12 #1
Har du MySQL ODBC driver version 2.x eller 3.x installeret ?

"driver={MySQL};..." er korrekt for 2.50

men for 3.51 er det "driver={MySQL ODBC 3.51 Driver};..."
Avatar billede beorndesign Nybegynder
16. januar 2005 - 22:36 #2
Jamen det var jo det. Tak. I flg. min internetudbyder skulle det være "driver={MySQL};...", så det regnede jeg med var rigtigt!

Men jeg støtte på en anden lille fejl, som hurtigt var løst. I min web.config fil skulle jeg lige have dette med:

      <compilation debug="true">
        <assemblies>
                <add assembly="Microsoft.Data.Odbc, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
                <add assembly="System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
        </assemblies>
      </compilation>

Et andet spørgsmål (hvis du kan svare på det): Hvad gør add assembly? Siden virker fint uden linien <add assembly="System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>. Skal den være der? Eller er det uden betydning?

Smid et svar, og du skal få dine point ;)
Avatar billede arne_v Ekspert
16. januar 2005 - 22:50 #3
De har nok opdateret deres MySQL ODBC driver uden at opdatere deres vejledning.

Det tag tilføjer en reference til en assembly når ASP.NET dynamisk compiler.

Du bruger vel ikke nogle klasser fra System.Data namespace og derfor er den ikke nødvendig !?
Avatar billede arne_v Ekspert
16. januar 2005 - 22:50 #4
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