加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net – 插入未编译

发布时间:2020-12-16 06:43:31 所属栏目:asp.Net 来源:网络整理
导读:为什么这个插入没有被编译: – INSERT INTO dbo.UserGroupsToUsers ( UserID,LastUpdated,ID,UserGroupID ) SELECT @MergeToUserID,GETDATE(),MAX(ID) + 1,UserGroupID FROM dbo.UserGroupsToUsers WHERE UserID = @MergeFromUserID 错误:列’dbo.UserGrou
为什么这个插入没有被编译: –

INSERT  INTO dbo.UserGroupsToUsers
                        ( UserID,LastUpdated,ID,UserGroupID 
                        )
                        SELECT  @MergeToUserID,GETDATE(),MAX(ID) + 1,UserGroupID
                        FROM    dbo.UserGroupsToUsers
                        WHERE   UserID = @MergeFromUserID

错误:列’dbo.UserGroupsToUsers.UserGroupID’在选择列表中无效,因为它不包含在聚合函数中,并且没有GROUP BY子句.

解决方法

您应该将您的ID字段设置为 IDENTITY(自动增量字段)并从查询中省略它.

如果您无法更改数据库,可以尝试这样做:

INSERT  INTO dbo.UserGroupsToUsers
                ( UserID,UserGroupID 
                )
                SELECT  @MergeToUserID,(SELECT MAX(ID) + 1 FROM dbo.UserGroupsToUsers),UserGroupID
                FROM    dbo.UserGroupsToUsers
                WHERE   UserID = @MergeFromUserID

重要说明:这假定只返回一行.如果子查询返回多行且ID是主键或具有唯一约束,则插入将失败.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读