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();
}
}
展开
 我来答
luo2008vip
2011-06-17 · TA获得超过105个赞
知道小有建树答主
回答量:226
采纳率:0%
帮助的人:163万
展开全部
问题出在 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)

其它的基本上都正确,鉴定完毕
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
aini6699
2011-06-16 · TA获得超过3750个赞
知道小有建树答主
回答量:963
采纳率:100%
帮助的人:250万
展开全部
我看你里面好像有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)。就可以了。
追问
要怎么把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的取值,你在试试。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
154vpbuwy
2011-06-17 · TA获得超过3772个赞
知道大有可为答主
回答量:4585
采纳率:0%
帮助的人:910万
展开全部
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 支持。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式