このコードを使用して、アプリケーションをテキストボックス内のテキストにフィルター処理しますが、これを拒否し、エラーメッセージがポップアップし続けます。コードは次のとおりです。Microsoft Accessデータベースの検索データをフィルター処理し、DataGridviewのフィルターを使用します。C#
using System.Windows.Forms;
using System.Configuration;
using System.Data.OleDb;
namespace TestBarcode
{
public partial class StaffHome : Form
{
private OleDbConnection connection = new OleDbConnection();
public StaffHome()
{
InitializeComponent();
connection.ConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=E:\Projects\POS\Database\MainDatabase_POS.accdb;Persist Security Info=False;";
}
private void StaffHome_Load(object sender, EventArgs e)
{
try
{
connection.Open();
OleDbCommand command = new OleDbCommand();
command.Connection = connection;
string query = "select * from InventoryManagement";
command.CommandText = query;
OleDbDataAdapter da = new OleDbDataAdapter(command);
DataTable dt = new DataTable();
da.Fill(dt);
dataGridView1.DataSource = dt;
connection.Close();
}
catch (Exception ex)
{
MessageBox.Show("Error" + ex);
}
}
try
{
connection = new OleDbConnection();
connection.Open();
OleDbCommand command = new OleDbCommand("Select * from InventoryManagement where ID like '" + textBox1.Text + "%'", connection);
OleDbDataAdapter adp = new OleDbDataAdapter(command);
DataTable dt = new DataTable();
adp.Fill(dt);
dataGridView1.DataSource = dt;
}
catch(Exception ex)
{
MessageBox.Show("Error" + ex);
}
これを行う方法はありますか?もしそうなら、助けてください。ありがとう。
EDIT:ここにはエラーmsgの画像があります。 Error msg Box
最初:上記のコードはコンパイル可能ではないようです。 (これらの2つの異なる方法はありますか?該当するコードを追加してください)。データテーブルInventoryManagementの列IDのタイプは何ですか?第三に、正確にエラーメッセージは何ですか?申し訳ありませんが、これらの重要な情報を追加しないと、あなたの質問は「あなたが何を求めているのか不明」というカテゴリに属します。 – Steve
ありがとうございました。 まず、同じコードですが、テキストボックスにテキストを挿入するまではプログラムが正常に機能するためです。 第2に、 ID、BarcodeID、Price、Quantityなど、いくつかの列があります。 第3に、私は上記のテキストを編集し、私のエラーの画像を追加します。再度 これを指摘してくれてありがとう。 –