【问题标题】:C# Access databaseC# 访问数据库
【发布时间】:2013-02-11 09:23:04
【问题描述】:

我正在尝试连接到我们的数据库并创建一个程序,该程序从表中读取并将信息发送到文本框/标签。我收到一个错误:

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.";
                    }
                }
            }
        }
    }
}

【问题讨论】:

  • 您刚刚发布了异常类型。消息和堆栈跟踪是什么?

标签: c# mysql visual-studio-2012


【解决方案1】:

尝试更改表名,可能是编码问题。 此外,您可能会发现这很有用:http://www.alinq.org/

请发布所有例外情况,以便人们可以提供帮助:)

【讨论】:

  • 这不是真正的答案,因为您不知道异常。
【解决方案2】:

我假设您正在尝试打开一个仍处于打开状态的连接。

OleDbConnection.Open Method

InvalidOperationException: 连接已经打开。

  • 使用using-statement 确保尽快处理/关闭所有内容。使用连接池(默认)时,您没有关闭连接,这是一个坏主意
  • 您尝试访问三个字段,但只选择查询中的两列?
  • 不要连接 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.";
        }
    }
}

【讨论】:

  • 你能翻译一下错误吗?我假设它说“selectcommand.connection 属性尚未初始化。”?
  • @JanesAbouChleih:是的:unlocalize.com/sv/… 所以数据适配器的连接还没有初始化。使用我的代码和有效的连接字符串。
  • 看看 Tim Schmelter 的回答。您必须将 sql 连接提供给 OleDBAdapter-Object:OleDbDataAdapter da = new OleDbCommand(SqlString, conn)
  • @janitso:您知道您正在尝试访问三个字段但只在查询中选择两列?因此我添加了第三列Fält1
  • 我对这一行有疑问:使用 (OleDbConnection conn = new OleDbConnection(ConnString)) 错误 2 无法将类型 'System.Data.OleDb.OleDbCommand' 隐式转换为 'System.Data.OleDb.OleDbDataAdapter '
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-12-26
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-10-15
  • 2010-09-05
  • 2011-07-14
相关资源
最近更新 更多