sql错误 帮忙看看啊

挨踢直男 2010-08-04 04:02:43
 string StrSQL = "UPDATE * FROM v_Company SET Company_Name = " +
"@Company_Name,Abbreviation = @Abbreviation ," +
" Company_Address = @Company_Address, Company_Tel = " +
"@Company_Tel,Company_Explain = @Company_Explain WHERE User_ID=@User_ID";
SqlConnection DbConn = new DataBase().Open();
SqlCommand thisCommand = DbConn.CreateCommand();
thisCommand.CommandText = StrSQL;
thisCommand.CommandType = CommandType.Text;
thisCommand.Parameters.Add("@Company_Name", SqlDbType.NVarChar, 20).Value = Company_Name.Text;
thisCommand.Parameters.Add("@Abbreviation", SqlDbType.NVarChar, 10).Value = Abbreviation.Text;
thisCommand.Parameters.Add("@Company_Address", SqlDbType.NVarChar, 50).Value = Company_Address.Text;
thisCommand.Parameters.Add("@Company_Tel", SqlDbType.VarChar, 20).Value = Company_Tel.Text;
thisCommand.Parameters.Add("@Company_Explain", SqlDbType.NVarChar, 4000).Value = Company_Explain;
thisCommand.Parameters.Add("@User_ID", SqlDbType.NVarChar, 20).Value = UserId;
int Count = thisCommand.ExecuteNonQuery();
DbConn.Close();


出现错误
System.InvalidCastException: 对象必须实现 IConvertible。

这是什么原因啊
...全文
84 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
无涯大者 2010-08-04
  • 打赏
  • 举报
回复
7楼的 有点道理
挨踢直男 2010-08-04
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 zhanlixin 的回复:]

thisCommand.Parameters.Add("@Company_Explain", SqlDbType.NVarChar, 4000).Value = Company_Explain
改为:
thisCommand.Parameters.Add("@Company_Explain", SqlDbType.NVarChar, 4000).Value = Company_Explain……
[/Quote]

谢谢
Zhanlixin 2010-08-04
  • 打赏
  • 举报
回复
thisCommand.Parameters.Add("@Company_Explain", SqlDbType.NVarChar, 4000).Value = Company_Explain
改为:
thisCommand.Parameters.Add("@Company_Explain", SqlDbType.NVarChar, 4000).Value = Company_Explain.Text
jointan 2010-08-04
  • 打赏
  • 举报
回复
Company_Explain和UserID的类型是什么?是string吗?
q107770540 2010-08-04
  • 打赏
  • 举报
回复
把你的参数转换到合适的类型去,譬如,如果一个参数的类似是int,你需要这么做

string s = "123 ";
SomeParam.Value = Convert.ToInt32(s);
挨踢直男 2010-08-04
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 q107770540 的回复:]

UPDATE * FROM v_Company SET Company_Name

============

UPDATE v_Company SET Company_Name
[/Quote]

不是这个 这个是写错的
porschev 2010-08-04
  • 打赏
  • 举报
回复
这个是绑定在哪个数据源上了吗?

出错的地方不应该在这里吧
Zhanlixin 2010-08-04
  • 打赏
  • 举报
回复
SQL语句改为:
string StrSQL = "UPDATE v_Company SET Company_Name = " +
"@Company_Name,Abbreviation = @Abbreviation ," +
" Company_Address = @Company_Address, Company_Tel = " +
"@Company_Tel,Company_Explain = @Company_Explain WHERE User_ID=@User_ID";
q107770540 2010-08-04
  • 打赏
  • 举报
回复
UPDATE * FROM v_Company SET Company_Name

============

UPDATE v_Company SET Company_Name

110,535

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧