sql – 操作数类型冲突:uniqueidentifier与int不兼容

前端之家收集整理的这篇文章主要介绍了sql – 操作数类型冲突:uniqueidentifier与int不兼容前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当我尝试创建下面的存储过程时,我得到以下错误

Operand type clash: uniqueidentifier is incompatible with int

我不清楚是什么导致这个错误. UserID实际上是我所有表中的一个int.有人可以告诉我我做错了什么吗?

create procedure dbo.DeleteUser(@UserID int)
as

    delete from [aspnet_Membership] where UserId = @UserID
    delete from [Subscription] where UserID = @UserID
    delete from [Address] where UserID = @UserID
    delete from [User] where UserID = @UserID

go

解决方法

对我来说,至少有一个表格将UserID定义为uniqueidentifier,而不是int.你检查了每张表中的数据吗?每个表中SELECT TOP 1 UserID的结果如何? int或GUID?

编辑

我认为你已经建立了一个基于所有表的程序,它包含一个名为UserID的列.我认为你不应该在脚本中包含aspnet_Membership表,因为它不是真正的“你的”表之一.

如果您打算在aspnet_Membership数据库周围设计表格,那么当该表格明确地为UserID列使用唯一标识符时,为什么剩下的列为int?

猜你在找的MsSQL相关文章