Avatar billede sidenius Nybegynder
21. august 2008 - 10:58 Der er 4 kommentarer og
1 løsning

Problemer med Access 2007 og C#-kode

Hej , jeg er ikke så stærk på C# eller Access , men har prøvet at lave fl.g test-kode for at få adgang til min database:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;


namespace DatabaseEksempel
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btn_Click(object sender, EventArgs e)
        {
            OleDbConnection MyConnection = null;
            OleDbDataReader dbReader = null;

            MyConnection = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0; User Id=; Password=; Data Source=C:\Documents and Settings\Lars\Dokumenter\Filmliste1.mdb");
            MyConnection.Open();

            OleDbCommand cmd = MyConnection.CreateCommand();
            cmd.CommandText = "SELECT * FROM Filmliste1";
            dbReader = cmd.ExecuteReader();

            string Titel;

            while(dbReader.Read())
            {
                Titel = (string)dbReader.GetValue(5);
                lb.Items.Add(Titel);
            }

            dbReader.Close();
            MyConnection.Close();
       



        }
    }
}


jeg får fl.g fejl når jeg kører det:

"Microsoft Office Access-databaseprogrammet kan ikke finde inputtabellen eller forespørgslen "Filmliste". Kontroller, at den findes, og at navnet er stavet korrekt."  Jeg aner ikke hvad der skal gøres.
Avatar billede sidenius Nybegynder
21. august 2008 - 13:05 #1
har ændret lidt på koden som ser således ud nu:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;


namespace DatabaseEksempel
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btn_Click(object sender, EventArgs e)
        {

            OleDbConnection Myconnection = null;
            OleDbDataReader dbReader = null;

            Myconnection = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\Documents and Settings\Lars\Dokumenter\Filmliste1.mdb");
            Myconnection.Open();

            OleDbCommand cmd = Myconnection.CreateCommand();
            cmd.CommandText = "SELECT * FROM Ark1";
            dbReader = cmd.ExecuteReader();

            string Titel;

            while (dbReader.Read())
            {
                Titel = dbReader.GetValue(5);
                lb.Items.Add(Titel);

            }

            dbReader.Close();
            Myconnection.Close();

        }
    }
}


jeg får nu en fejl der lyder: "InvalidCastException was unhandled"  . "Specified cast is not valid" ved linien "Titel = (string)dbReader.GetValue(5);"
Avatar billede sidenius Nybegynder
21. august 2008 - 13:24 #2
undskyld... fejlen lyder istedet for på "Invalid CastException was unhandled" . Unable to cast object of type 'System.DBNull' to type 'System.String'
Avatar billede arne_v Ekspert
22. august 2008 - 04:19 #3
Lyder som om du har en række hvor den sjette kolonne indeholder NULL.

Måske:

if(dbReader.IsDBNull(5))
    Titel = "missing";
else
    Titel = dbReader.GetValue(5);
Avatar billede sidenius Nybegynder
22. august 2008 - 09:32 #4
Det virkede...tak arne . Smid bare et svar retur
Avatar billede arne_v Ekspert
22. august 2008 - 14:59 #5
ok
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