-3

データベースに接続して、テーブルから読み取り、テキストボックス/ラベルに情報を取得するプログラムを作成しようとしています。エラーが発生します:

int numberOfRowsFeched = oleDbDataAdapter1.Fill(dataSet1, "Böcker");

エラー:InvalidOperationException

private void btn1_Click(object sender, EventArgs e)
    {

        {
            string sqlQuery = "SELECT Fält2, Fält3 FROM Böcker WHERE Fält2 = " + "'\\" + txt1.Text + "\\'";
            oleDbDataAdapter1.SelectCommand.CommandText = sqlQuery;
            dataSet1.Clear();
                oleDbConnection1.Open();
            int numberOfRowsFeched = oleDbDataAdapter1.Fill(dataSet1, "Böcker");
            if (numberOfRowsFeched > 0)
            {
                DataTable dt = dataSet1.Tables["Böcker"];
                lbl1.Text = dt.Rows[0][0].ToString() + " " +
                dt.Rows[0][1].ToString();
                lbl2.Text = dt.Rows[0][2].ToString();
            }
            else
            {
                lbl1.Text = "Boken hittades inte.";
                lbl1.Text = "";
            }
        }
    }
}

私が使用している新しいコード:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.Sql;
using System.Data.OleDb;
using System.Data.SqlClient;

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

        private void Form1_Load(object sender, EventArgs e)
        {

        }

        private void btn1_Click(object sender, EventArgs e)
        {
            string ConnString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\\Users\\cetin.cigel\\databasbibliotek.mdb;User Id=admin;Password=;";
            string SqlString = "SELECT Fält1, Fält2, Fält3 FROM Böcker WHERE Fält2 = ?";
            using (OleDbConnection conn = new OleDbConnection(ConnString))
            {
                using (OleDbDataAdapter da = new OleDbDataAdapter(SqlString, conn))
                {
                    da.SelectCommand.Parameters.AddWithValue("Fält2", txt1.Text);
                    DataTable dt = dataSet1.Tables["Böcker"];
                    da.Fill(dt);
                    if (dt.Rows.Count > 0)
                    {
                        string text = string.Format("{0} {1}",
                            dt.Rows[0].Field<string>(0),
                            dt.Rows[0].Field<string>(1));
                        lbl1.Text = text;
                        lbl2.Text = dt.Rows[0].Field<string>(2);
                    }
                    else
                    {
                        lbl1.Text = "Boken hittades inte.";
                    }
                }
            }
        }
    }
}
4

2 に答える 2

0

テーブル名を変更してみてください。エンコーディングに問題がある可能性があります。また、これが役立つ場合があります:http: //www.alinq.org/

そして、人々が助けることができるように、すべての例外を投稿してください:)

于 2013-02-11T09:27:42.743 に答える
0

まだ開いている接続を開こうとしていると思います。

OleDbConnection.Open方法

InvalidOperationException: 接続はすでに開いています。

  • -ステートメントを使用しusingて、すべてができるだけ早く破棄/クローズされるようにします。接続プールを使用する場合、接続を閉じていませんが、これは悪い考えです (デフォルト)。
  • 3 つのフィールドにアクセスしようとしているのに、クエリで 2 つの列しか選択していませんか?
  • SQL クエリを連結しないでください。代わりにパラメーターを使用してください。

string SqlString = "SELECT Fält1, Fält2, Fält3 FROM Böcker WHERE Fält2 = ?";
using (OleDbConnection conn = new OleDbConnection(ConnString))
{
    using (OleDbDataAdapter da = new OleDbDataAdapter(SqlString, conn))
    {
        da.SelectCommand.Parameters.AddWithValue("Fält2", txt1.Text);
        DataTable dt = dataSet1.Tables["Böcker"];
        da.Fill(dt);
        if (dt.Rows.Count > 0)
        {
            string text = string.Format("{0} {1}",
                dt.Rows[0].Field<string>(0),
                dt.Rows[0].Field<string>(1));
            lbl1.Text = text;
            lbl2.Text = dt.Rows[0].Field<string>(2);
        }
        else
        {
            lbl1.Text = "Boken hittades inte.";
        }
    }
}
于 2013-02-11T09:31:33.797 に答える