Avatar billede pham Nybegynder
10. august 2004 - 10:00 Der er 4 kommentarer og
1 løsning

SMALLDATETIME må ikke være "null"

Hej

Jeg har lavet et udtræk fra en SQL database hvor datatypen er SMALLDATETIME. Når jeg så vil have fat i den fra C# får jeg denne fejl:

Unhandled Exception: System.Data.SqlTypes.SqlNullValueException: Data is Null. This method or property cannot be called on Null values.
  at System.Data.SqlTypes.SqlDateTime.get_Value()
  at System.Data.SqlClient.SqlDataReader.GetDateTime(Int32 i)
  at MSSQLConnect.connect() in c:\Documents and Settings\Godballe\My Documents\
SharpDevelop Projects\ProxyApplikation\MSSQLConnect.cs:line 29
  at DefaultNamespace.MainClass.Main(String[] args) in c:\Documents and Setting
s\Godballe\My Documents\SharpDevelop Projects\ProxyApplikation\Main.cs:line 18
Press any key to continue . . .

Efter hvad jeg kan forstå er det at den ikke må være "null" men hvordan kommer jeg lige uden om dette problem da en masse af posterne i databasen er det?

Min kode er:

using System;
using System.Globalization;
using System.Data.SqlClient;

public class MSSQLConnect
{

    public void connect()
    {

        string connectionString = "server=***;" +
        "database=***;uid=***;pwd=***";

        SqlConnection con = new SqlConnection(connectionString);

        con.Open();

        SqlCommand cmd = new SqlCommand("SELECT * FROM macsys",con);
        SqlDataReader reader = cmd.ExecuteReader();


        while(reader.Read()) {
       
        Console.WriteLine(reader.GetDateTime(2));   
        }
        reader.Close();
        con.Close();
    }
}

Med venlig hilsen
Anders Hansen
Avatar billede snepnet Nybegynder
10. august 2004 - 10:08 #1
du kan lave en
DateTime dt = null;
while(reader.Read())
{
  try
  {
    dt = reader.GetDateTime(2);
  }
  catch(SqlNullValueException)
  {
    // hvad du gerne vil have der sker ved null
  }
}

Mvh
Avatar billede snepnet Nybegynder
10. august 2004 - 10:10 #2
men du kan også spørge direkte på == System.DbNull.Value - hvis det er en "naturlig" værdi, er måske ikke så pænt at betragte det som en exception i koden.
Avatar billede pham Nybegynder
10. august 2004 - 10:10 #3
hmm jeg fandt selv ud af det.. jeg brugte i stedet reader.GetSqlDateTime(2)); hvilket kan behandle "null" værdien..

men mange tak for det hurtige svar! :)

med venlig hilsen
Anders Hansen
Avatar billede snepnet Nybegynder
10. august 2004 - 10:11 #4
Sorry... det er med stort B (System.DBNull.Value)
Avatar billede snepnet Nybegynder
10. august 2004 - 10:12 #5
Velbekomme :o)
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