| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 759 人关注过本帖
标题:这个存储过程到底是什么原因造成这样怪异的错误???
只看楼主 加入收藏
kira007
Rank: 2
等 级:论坛游民
帖 子:294
专家分:27
注 册:2007-6-28
结帖率:50%
收藏
 问题点数:0 回复次数:2 
这个存储过程到底是什么原因造成这样怪异的错误???
以下是存储过程的一个部分
执行以下代码就会报错
服务器: 消息 8101,级别 16,状态 1,行 13
仅当使用了列的列表,并且 IDENTITY_INSERT 为 ON 时,才能在表 '#ProD' 中为标识列指定显式值。
把出错语句 (select Username from [User] where  [user].ID= Remsg.TouserId) 改为  ToUserId 就不出错了。
这是什么原因?

create table #ProD (viewID int IDENTITY, --自增字段
    ID int,
    Fromuser varchar(50),
    Reads int,
    ToUserId varchar(50),
    Title varchar(200),
    Repay nvarchar(1000),
    Retime datetime
    )
   
Insert into #ProD  
    select id,
    (select Username from [User] where  [user].ID= Remsg.Fromuser),
    [views],
    (select Username from [User] where  [user].ID= Remsg.TouserId),//就是这句出错了
    Title,Repay,Retime
    from [Remsg] where type = 0 and (FromUser = 0 or ToUserId = 0 ) order by ToUserId asc ,Retime desc
搜索更多相关主题的帖子: 怪异 
2010-09-16 11:08
qingshuiliu
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:17
帖 子:323
专家分:1538
注 册:2009-12-28
收藏
得分:0 
标识列(一般是主键),是不允许插入的,如果要插入的话
需要修改表结构,改为IDENTITY_INSERT 为 ON 时
2010-09-16 11:54
zhaoyang1008
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:30
专家分:110
注 册:2010-9-15
收藏
得分:0 
因为你在创建表#proD的时候给第一列戴上了identity属性,就是自动给属性赋值,如果不执行set identity_insert #prod on语句的话是不能手动在这一列插入数据的
但在插入完之后一定要再执行 set identity_insert #prod off语句
2010-09-18 16:29
快速回复:这个存储过程到底是什么原因造成这样怪异的错误???
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.010797 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved