heyguys,
我对此完全陌生...我想将我的记录从winform添加到访问数据库,该数据库已经是一个数据源但最终出现错误,其中包含:
OleDBException未处理,并且它说“语法错误” INSERT INTO声明。“
表示该行:
da.Update(ds1, "Table1");
我的编码是:
int MaxRows = 0;
int inc = 0;
private void Form2_Load(object sender, EventArgs e)
{
con = new System.Data.OleDb.OleDbConnection();
ds1 = new DataSet();
con.ConnectionString = " Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:/Documents and Settings/user/My Documents/anchu.accdb";
string sql = "SELECT * From Table1";
da = new System.Data.OleDb.OleDbDataAdapter(sql, con);
con.Open();
da.Fill(ds1, "Table1");
//NavigateRecords();
con.Close();
//con.Dispose();
}
/*private void NavigateRecords()
{
DataRow drow = ds1.Tables["Table1"].Rows[0];
textBox1.Text = drow.ItemArray.GetValue(0).ToString();
textBox2.Text = drow.ItemArray.GetValue(1).ToString();
textBox3.Text = drow.ItemArray.GetValue(2).ToString();
textBox4.Text = drow.ItemArray.GetValue(3).ToString();
}*/
private void groupBox1_Enter(object sender, EventArgs e)
{
}
private void button2_Click(object sender, EventArgs e)
{
textBox1.Clear();
textBox2.Clear();
textBox3.Clear();
textBox4.Clear();
}
private void button1_Click(object sender, EventArgs e)
{
System.Data.OleDb.OleDbCommandBuilder cb;
cb = new System.Data.OleDb.OleDbCommandBuilder(da);
DataRow drow = ds1.Tables["Table1"].NewRow();
drow[0] = textBox1.Text;
drow[1] = textBox2.Text;
drow[2] = textBox3.Text;
drow[3] = textBox4.Text;
ds1.Tables["Table1"].Rows.Add(drow);
MaxRows = MaxRows + 1;
inc = MaxRows - 1;
da.Update(ds1, "Table1");
MessageBox.Show("Entry Added");
}
}
}
答案 0 :(得分:2)
请您查看表格结构。 看来,表格字段不匹配。
例如:如果您有一个自动列,并且您向该列添加了一个值,它将抛出异常。 此外,即使表列匹配,也要检查数据类型和最大长度。
希望这能解决。
欢呼声
答案 1 :(得分:0)
OleDbCommandBuilder
在为像Access这样具有与PSQL或TSQL不同的语法要求的数据库系统构建语句时表现不佳。我会在生成CommandBuilder
之后添加一个断点,并查看它生成的SQL,看看它是否是Access的正确语法。
您最好自己构建INSERT语句,而不是假设命令构建器会为您正确构建它。