无法将参数值从字符串转换为guid

时间:2012-10-10 09:59:02

标签: asp.net n-tier-architecture tableadapter

我有一个分层应用程序。数据层使用包含tableadapter的数据集调用数据库。在数据库表中有一个名为ID UniqueIdentifier 的字段。然后我创建以下查询:

select * from tbl where ID=@ID

当我尝试在数据集设计器中预览结果时,我收到错误“无法将参数值从字符串转换为guid”。

我尝试在传入的值周围添加单引号,但没有用。

我哪里错了?

1 个答案:

答案 0 :(得分:8)

您的列ID是数据库中的Guid类型,但您的参数是string

您可以将参数转换为SqlGuid

command.Parameters.Add("@GuidParameter", SqlDbType.UniqueIdentifier).Value = new System.Data.SqlTypes.SqlGuid(YourGuid); //The value of @ID

链接:https://msdn.microsoft.com/library/system.data.sqltypes.sqlguid.aspx?f=255&MSPPError=-2147217396