C#,如何把修改后的数据存回数据库
有一张表,有Type,PayType,Pay,Day,Number五个列,程序中有4个对应的textbox和一个DateTimePicker(已改名为dateTime)。...
有一张表,有Type,PayType,Pay,Day,Number五个列,程序中有4个对应的textbox和一个DateTimePicker(已改名为dateTime)。我想将各个textbox里填写的内容存到数据库里。可是总显示“添加失败”。请问要如何修改?
代码如下:
private void 保存ToolStripMenuItem_Click(object sender, EventArgs e)
{
OleDbConnection conn = new OleDbConnection ("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=kcDB.mdb");
string sql = "Insert into Recover(Type,PayType,Pay,Day,Number)values('" + txtType.Text + "','" + txtPayType.Text + "','" + txtPay.Text + "','" + dateTime.Text + "'" + txtRemember.Text + "')";
OleDbCommand cmd = new OleDbCommand(sql, conn);
conn.Open();
try
{
int i = cmd.ExecuteNonQuery();
MessageBox.Show("添加成功");
}
catch
{
MessageBox.Show("添加失败");
}
finally
{
conn.Close();
}
} 展开
代码如下:
private void 保存ToolStripMenuItem_Click(object sender, EventArgs e)
{
OleDbConnection conn = new OleDbConnection ("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=kcDB.mdb");
string sql = "Insert into Recover(Type,PayType,Pay,Day,Number)values('" + txtType.Text + "','" + txtPayType.Text + "','" + txtPay.Text + "','" + dateTime.Text + "'" + txtRemember.Text + "')";
OleDbCommand cmd = new OleDbCommand(sql, conn);
conn.Open();
try
{
int i = cmd.ExecuteNonQuery();
MessageBox.Show("添加成功");
}
catch
{
MessageBox.Show("添加失败");
}
finally
{
conn.Close();
}
} 展开
3个回答
展开全部
问题出在 Sql 语句上和类型转换问题上
完整的Sql语句应该为 string sql = "Insert into Recover(Type,PayType,Pay,Day,Number) values('" + txtType.Text + "','" + txtPayType.Text + "','" + txtPay.Text + "','" + dateTime.Text + "'" + txtRemember.Text + "')";
values(XX) 前面要有空格 而且值是String类型的一定要有单引号
如果数据库有datetime类型字段,插入数据库前一定要先转换成datetime类型
datetime.Parse(XX)
其它的基本上都正确,鉴定完毕
完整的Sql语句应该为 string sql = "Insert into Recover(Type,PayType,Pay,Day,Number) values('" + txtType.Text + "','" + txtPayType.Text + "','" + txtPay.Text + "','" + dateTime.Text + "'" + txtRemember.Text + "')";
values(XX) 前面要有空格 而且值是String类型的一定要有单引号
如果数据库有datetime类型字段,插入数据库前一定要先转换成datetime类型
datetime.Parse(XX)
其它的基本上都正确,鉴定完毕
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我看你里面好像有datetime类型的值吧,建议改成nvarchar,dateTime.Text 应该是dateTime.Value.toString(),还有建议你去掉try catch 有这个看不出毛病了。
int i = cmd.ExecuteNonQuery();
if(i>0)
{
MessageBox.Show("添加成功");
}
else
{
MessageBox.Show("添加失败");
}
conn.Close();
显示取值的时候把sting类型的datetime强制转换成时间类型显示在DateTimePicker(已改名为dateTime)。就可以了。
int i = cmd.ExecuteNonQuery();
if(i>0)
{
MessageBox.Show("添加成功");
}
else
{
MessageBox.Show("添加失败");
}
conn.Close();
显示取值的时候把sting类型的datetime强制转换成时间类型显示在DateTimePicker(已改名为dateTime)。就可以了。
追问
要怎么把string类型强制转换成时间类型呢?try那里我已经按照你的指导改过来了,可是运行的时候“int i=cmd.ExecuteNonQuery”这里显示“insert into语句的语法错误”,要怎么改正呢?
追答
DateTime.Parse(s);就可以强制转换,s是string类型。
string mysql = "insert into 表名(jhid,bh,nd,jhmc,yqlb,bzry,sssj,pzry,pzsj) values('" + jhid + "','" + bh + "','" + nd + "','" + jhmc + "','" + yqlb + "','" + bzry + "','" + sssj + "','" + pzry + "','" + pzsj + "')";
上面是插入语句
this.dateTimePicker1.Value.ToString();这是dateTimePicker1的取值,你在试试。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
DbDataAdapter.Update (DataRow[]) 为指定的 DataRow 对象数组中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataSet) 为指定 DataSet 中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataTable) 为指定 DataTable 中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataRow[], DataTableMapping) 为指定的 DataRow 对象数组中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataSet, String) 为具有指定 DataTable 名称的 DataSet 中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataSet) 为指定 DataSet 中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataTable) 为指定 DataTable 中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataRow[], DataTableMapping) 为指定的 DataRow 对象数组中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
DbDataAdapter.Update (DataSet, String) 为具有指定 DataTable 名称的 DataSet 中每个已插入、已更新或已删除的行调用相应的 INSERT、UPDATE 或 DELETE 语句。
由 .NET Compact Framework 支持。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询