从 System.String 到 System.Guid 的转换无效——我怎么给指定guid类型的数据?

ncowboy 2005-05-29 12:19:00
代码:
public string GetUsernameByUserID(string uid)
{
this.sqlCommand.CommandText="SELECT ISNULL(MAX(USERNAME),'') FROM USERINFO WHERE ID=@ID";
this.sqlCommand.Parameters.Clear();
this.sqlCommand.Parameters.Add(new System.Data.SqlClient.SqlParameter("@ID",System.Data.SqlDbType.UniqueIdentifier));
this.sqlCommand.Parameters["@ID"].Value=uid;
return sqlCommand.ExecuteScalar().ToString();
}

我的应用程序提示我
从 System.String 到 System.Guid 的转换无效。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.InvalidCastException: 从 System.String 到 System.Guid 的转换无效。
...全文
334 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
hackate 2005-05-29
  • 打赏
  • 举报
回复
汗,看错了语句,我哭
DeltaCat 2005-05-29
  • 打赏
  • 举报
回复
this.sqlCommand.Parameters["@ID"].Value = new Guid(uid);
ncowboy 2005-05-29
  • 打赏
  • 举报
回复
不指定为“System.Data.SqlDbType.UniqueIdentifier”,指定为“System.Data.SqlDbType.NVarChar,36”
ncowboy 2005-05-29
  • 打赏
  • 举报
回复
问题已经解决:

this.sqlCommand.Parameters.Add(new System.Data.SqlClient.SqlParameter("@OWNER",System.Data.SqlDbType.NVarChar,36));
ncowboy 2005-05-29
  • 打赏
  • 举报
回复
我的是select,将一个guid作为条件。而不是insert into。
hackate 2005-05-29
  • 打赏
  • 举报
回复
你不用这样做。你直接在你的SQL数据库的USERINFO表中把你这个ID这个字段设置为UniqueIdentifier数据类型。然后设置“默认值是”===="newid()"

这样你添加一条纪录的时候就不用去设置ID了,他会自动给个唯一性的GUID,象自增列一样啦!

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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