我目前正在使用SQL Server,ASP.net web API 2和Entity framework6技术开发应用程序。
我在下面有一个存储过程:
create procedure [dbo].[get_users_timesheets]
(
@user_id int,
@approved_type bit,
@location_id int,
@page_size int,
@page int,
@count int output
)
as
begin
DECLARE @SQL varchar(1000)
SET @SQL = 'select * from bs_user_timesheets WHERE
location_id='+STR(@location_id)
IF(@user_id!=-1) SET @SQL = @SQL + ' and user_id='+STR(@user_id)+''
if(@approved_type!='') set @SQL=@SQL+'and approved='+STR(@approved_type)+''
SET @SQL=@SQL+' order by [id] desc'
SET @SQL=@SQL+' OFFSET (('+STR(@page)+'-1)*'+STR(@page_size)+') ROWS'
SET @SQL=@SQL+' FETCH NEXT '+STR(@page_size)+' ROWS ONLY'
exec(@SQL)
SET @count = @@ROWCOUNT
end
我的问题是:一旦我运行以下方法,而不是获取DB中的实际记录数,我在“RetunValue”字段中的所有时间都是“1”,无论我存储了多少条记录。 / p>
object[] parameter = {
new SqlParameter("@ParametterWithNummvalue", DBNull.Value),
new SqlParameter("@user_id",user_id),
new SqlParameter("@approved_type",approved_type),
new SqlParameter("@location_id",location_id),
new SqlParameter("@page_size",general.page_size),
new SqlParameter("@page",page),
new SqlParameter("@count", SqlDbType.Int) {Direction= ParameterDirection.Output}
};
var query = DB.Database.SqlQuery<bs_user_timesheets>("dbo.get_users_timesheets @user_id,@approved_type,@location_id,@page_size,@page,@count output", parameter);
var result = await query.ToListAsync();
var ReturnValue = ((SqlParameter)parameter[5]).Value;
如果有人告诉我如何解决这个问题以获取“ReturnValue”字段中的实际记录数量,我将不胜感激?!
答案 0 :(得分:0)
@@ Rowcount将返回受最后一个语句影响的行数。我猜最后一句话总是影响一条记录。您应该直接执行查询以验证这一点。