asp.net+sql数据库做网页,cmd.ExecuteNonQuery();错误:不存在从对象类型 System.String[] 到已知的...
答案:2 悬赏:20 手机版
解决时间 2021-03-23 23:21
- 提问者网友:趣果有间
- 2021-03-23 13:54
asp.net+sql数据库做网页,cmd.ExecuteNonQuery();错误:不存在从对象类型 System.String[] 到已知的...
最佳答案
- 五星知识达人网友:酒安江南
- 2021-03-23 15:26
cmd.Parameters.AddWithValue("bargainbookID", GridView1.DataKeyNames);
变量不对,还有类型不匹配,DataKeyNames这是数组类型追问我以为GridView1.DataKeyNames是GridView1提供的主键,此处要获取该主键,该怎么获取?追答DataKeyNames取得是主键列的 名字 数组:比如{“id0”,"id1"}
你要取主键值得话用DataKeys[i].Value表时i行第0主键列的值
因为key可能包含多个字段,就像数据库一样
DataKeys[i].Values[j];
i表示的是第几行
j表示主键的第几列
变量不对,还有类型不匹配,DataKeyNames这是数组类型追问我以为GridView1.DataKeyNames是GridView1提供的主键,此处要获取该主键,该怎么获取?追答DataKeyNames取得是主键列的 名字 数组:比如{“id0”,"id1"}
你要取主键值得话用DataKeys[i].Value表时i行第0主键列的值
因为key可能包含多个字段,就像数据库一样
DataKeys[i].Values[j];
i表示的是第几行
j表示主键的第几列
全部回答
- 1楼网友:老鼠爱大米
- 2021-03-23 16:15
那句有问题 分析那里
你单步调试啊追问倒数第三句 cmd.ExecuteNonQuery();
报错:不存在从对象类型 System.String[] 到已知的托管提供程序本机类型的映射。追答cmd.Parameters.AddWithValue("@username", Session["username"]);
cmd.Parameters.AddWithValue("@tosb",TextBox2.Text );
cmd.Parameters.AddWithValue("@address",TextBox3.Text );
cmd.Parameters.AddWithValue("@youbian",TextBox4.Text );
cmd.Parameters.AddWithValue("bargainbookID", GridView1.DataKeyNames); cmd.Parameters.AddWithValue("@bookamount", GridView1.Rows[k].Cells[8]);
cmd.Parameters.AddWithValue("@date",System.DateTime.Now);
应该是上面这些参数提供的有问题,你都在后面加上toString()试试追问刚才加了试了下,仍然不行,还是 cmd.ExecuteNonQuery();这句报错未处理的异常追答看了下 应该是xiao01j 这哥们说的问题
你要获得字段,既然是数组类型的,怎么获得数组元素,你应该会吧,DataKeyNames[k]
你单步调试啊追问倒数第三句 cmd.ExecuteNonQuery();
报错:不存在从对象类型 System.String[] 到已知的托管提供程序本机类型的映射。追答cmd.Parameters.AddWithValue("@username", Session["username"]);
cmd.Parameters.AddWithValue("@tosb",TextBox2.Text );
cmd.Parameters.AddWithValue("@address",TextBox3.Text );
cmd.Parameters.AddWithValue("@youbian",TextBox4.Text );
cmd.Parameters.AddWithValue("bargainbookID", GridView1.DataKeyNames); cmd.Parameters.AddWithValue("@bookamount", GridView1.Rows[k].Cells[8]);
cmd.Parameters.AddWithValue("@date",System.DateTime.Now);
应该是上面这些参数提供的有问题,你都在后面加上toString()试试追问刚才加了试了下,仍然不行,还是 cmd.ExecuteNonQuery();这句报错未处理的异常追答看了下 应该是xiao01j 这哥们说的问题
你要获得字段,既然是数组类型的,怎么获得数组元素,你应该会吧,DataKeyNames[k]
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯