繁体   English   中英

IndexOutOfRangeException SqlDataReader从表中读取布尔值

[英]IndexOutOfRangeException SqlDataReader reading bool value from table

我有3个表: usersfeed(id,body,title,link)userstofeed(id,userid,feedid,isread)而我试图从userstofeed表中读取bool值时,它带来了IndexOutOfRangeException 告诉我我在做什么错

while (reader.Read())
{
     rssFeed.Title = reader["title"].ToString();
     rssFeed.Body = reader["body"].ToString();
     rssFeed.Link = reader["link"].ToString();
     rssFeed.IsRead = (bool) reader["isread"]; //IndexOutOfRangeException here
     yield return rssFeed;
}

而这里的SQL存储过程:

create proc spGetItemsByUser
@userName nvarchar(50)
as
begin
declare @userId int
declare @feedId table (id int)

select @userId = id 
from Users 
where name = @userName

insert into @feedid (id)
select feedid, isread 
from userstofeed 
where userid = @userId

select * from feed where id in (select id from @feedId)
select isread from userstofeed where userid = @userId //Here I'm getting bit if it read or not
end

将存储过程中的SELECT更改为此:

SELECT [feed].[title], [feed].[body], [feed].[link], [userstofeed].[isread]
FROM [feed]
INNER JOIN [userstofeed] ON ([userstofeed].userid = @userId)
WHERE [feed].[id] in (select id from @feedId)

我认为在您的版本中isread不是第一个结果集的列。 isread值将作为titlefeedbody行的后面追加。


正如Zohar Peled所建议的那样,我尝试对整个存储过程进行重构:

CREATE PROC spGetItemsByUser
   @userName nvarchar(50)
AS
BEGIN
    SELECT [feed].[title], [feed].[body], [feed].[link], [userstofeed].[isread]
    FROM [feed]
    INNER JOIN [userstofeed] ON ([userstofeed].[feedid] = [feed].[id])
    INNER JOIN [users] ON ([users].[id] = [userstofeed].[userid])
    WHERE [users].[name] = @userName
END

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM