使用 PetaPoco 执行参数化存储过程

发布于 2024-12-23 13:20:22 字数 4110 浏览 7 评论 0原文

我花了两天时间与 PetaPoco 努力实现一个搜索解决方案(显然带有一些搜索参数),该解决方案在数据库中具有自定义分页。我不知道如何使用 ASP.NET DataPager 配置 PetaPoco 分页(这是一个完全不同的问题)。无论如何,我想在数据库中使用自定义分页。

我有一个名为 GetUsersPaged 的存储过程,如下所示:

ALTER PROCEDURE [dbo].[GetUsersPaged] 
@startRowIndex int,
@maximumRows int,
@name nvarchar(300) = NULL,
@email nvarchar(100) = NULL
AS
BEGIN
    SELECT *
    FROM 
    (
    SELECT *,
            ROW_NUMBER() OVER(ORDER BY Id) AS RowRank
            FROM UserInfo
            WHERE 
        (Nickname LIKE '%'+@name+'%' 
         OR FirstName LIKE '%'+@name+'%' 
         OR LastName LIKE '%'+@name+'%' 
         OR @name IS NULL) 
            AND 
        (Email = @email OR @email IS NULL)

    ) AS UsersPagedList
    WHERE RowRank BETWEEN @startRowIndex AND (@startRowIndex + @maximumRows) 
END

GetUsersCount 存储过程,如下所示:

    ALTER PROCEDURE [dbo].[GetUsersCount] 
    @name nvarchar(300) = NULL,
    @email nvarchar(100) = NULL
    AS
    BEGIN
   SELECT COUNT(*)
       FROM UserInfo
       WHERE 
    (Nickname LIKE '%'+@name+'%' 
     OR FirstName LIKE '%'+@name+'%' 
     OR LastName LIKE '%'+@name+'%' 
     OR @name IS NULL) 
        AND 
    (Email = @email OR @email IS NULL)
   END

现在我有两种调用这些存储过程的方法,如下所示:

    [DataObjectMethod(DataObjectMethodType.Select, false)]
    public List<DAL.UserInfo> GetPagedUserSearchResults(int startRowIndex, int pageSize, string name, string email)
    {
        DBService dbService = new DBService();
        var db = dbService.GetDatabase();
        var list = new List<DAL.UserInfo>();

        if(name != string.Empty && email != string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1, 
                                            @@name = @2, @@email = @3", startRowIndex, pageSize, name, email);

        else if(name == string.Empty && email != string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1, 
                                            @@email = @2", startRowIndex, pageSize, email);

        else if(name != string.Empty && email == string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1, 
                                            @@name = @2", startRowIndex, pageSize, name);

        else if(name == string.Empty && email == string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1"
                                            ,startRowIndex, pageSize); 
        return list;
    }

    [DataObjectMethod(DataObjectMethodType.Select, false)]
    public int GetPagedUserSearchResultsCount(string name, string email)
    {
        DBService dbService = new DBService();
        var db = dbService.GetDatabase();
        IEnumerable<DAL.UserInfo> count = null;

        if (name != string.Empty && email != string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount @@name = @0, @@email = @1", name, email);

        else if (name == string.Empty && email != string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount @@email = @0", email);

        else if(name != string.Empty && email == string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount @@name = @0", name);

        else if (name == string.Empty && email == string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount");

        return count.Count<DAL.UserInfo>();
    }

我的问题是:一切都是当我在数据库(SQL Management Studio 内部)中执行和测试存储过程时,效果很好。所有结果均与寻呼参数有关。但是当我使用 PetaPoco 调用相同的存储过程时,它会获取整个内容并且分页被忽略。

例如,当我在 SQL Management Studio 中测试存储过程时

@startRowIndex = 0
@maximumRows = 1

,我没有为 @name@email 发送任何内容,它只返回一行,这是完全正确的。但与 PetaPoco 相同,它在列表中返回 3 行。知道有什么问题吗?

It's been two days I'm wrestling with PetaPoco to implement a search solution (evidently with some search parameters) which has custom paging in database. I couldn't figure out how to configure PetaPoco paging with ASP.NET DataPager (which is a whole different question). Anyway I want to use custom paging in database.

I have a stored proc called GetUsersPaged like below:

ALTER PROCEDURE [dbo].[GetUsersPaged] 
@startRowIndex int,
@maximumRows int,
@name nvarchar(300) = NULL,
@email nvarchar(100) = NULL
AS
BEGIN
    SELECT *
    FROM 
    (
    SELECT *,
            ROW_NUMBER() OVER(ORDER BY Id) AS RowRank
            FROM UserInfo
            WHERE 
        (Nickname LIKE '%'+@name+'%' 
         OR FirstName LIKE '%'+@name+'%' 
         OR LastName LIKE '%'+@name+'%' 
         OR @name IS NULL) 
            AND 
        (Email = @email OR @email IS NULL)

    ) AS UsersPagedList
    WHERE RowRank BETWEEN @startRowIndex AND (@startRowIndex + @maximumRows) 
END

and GetUsersCount stored proc like below:

    ALTER PROCEDURE [dbo].[GetUsersCount] 
    @name nvarchar(300) = NULL,
    @email nvarchar(100) = NULL
    AS
    BEGIN
   SELECT COUNT(*)
       FROM UserInfo
       WHERE 
    (Nickname LIKE '%'+@name+'%' 
     OR FirstName LIKE '%'+@name+'%' 
     OR LastName LIKE '%'+@name+'%' 
     OR @name IS NULL) 
        AND 
    (Email = @email OR @email IS NULL)
   END

Now I have two methods for calling these stored procs like below:

    [DataObjectMethod(DataObjectMethodType.Select, false)]
    public List<DAL.UserInfo> GetPagedUserSearchResults(int startRowIndex, int pageSize, string name, string email)
    {
        DBService dbService = new DBService();
        var db = dbService.GetDatabase();
        var list = new List<DAL.UserInfo>();

        if(name != string.Empty && email != string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1, 
                                            @@name = @2, @@email = @3", startRowIndex, pageSize, name, email);

        else if(name == string.Empty && email != string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1, 
                                            @@email = @2", startRowIndex, pageSize, email);

        else if(name != string.Empty && email == string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1, 
                                            @@name = @2", startRowIndex, pageSize, name);

        else if(name == string.Empty && email == string.Empty)
            list = db.Fetch<DAL.UserInfo>(@"EXEC GetUsersPaged @@startRowIndex = @0, @@maximumRows = @1"
                                            ,startRowIndex, pageSize); 
        return list;
    }

    [DataObjectMethod(DataObjectMethodType.Select, false)]
    public int GetPagedUserSearchResultsCount(string name, string email)
    {
        DBService dbService = new DBService();
        var db = dbService.GetDatabase();
        IEnumerable<DAL.UserInfo> count = null;

        if (name != string.Empty && email != string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount @@name = @0, @@email = @1", name, email);

        else if (name == string.Empty && email != string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount @@email = @0", email);

        else if(name != string.Empty && email == string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount @@name = @0", name);

        else if (name == string.Empty && email == string.Empty)
            count = db.Query<DAL.UserInfo>("EXEC GetUsersCount");

        return count.Count<DAL.UserInfo>();
    }

My question is: everything is fine when I'm executing and testing stored procs in db (inside SQL Management Studio). All results respect to paging parameters. But when I call the same stored procs using PetaPoco, it fetches the whole thing and paging is ignored.

For example when I test stored procs in SQL Management Studio with

@startRowIndex = 0
@maximumRows = 1

and I don't send anything for @name and @email, it returns just one row which is totally correct. But the same things with PetaPoco, it returns 3 rows in the list. Any idea what's the problem?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

爱你不解释 2024-12-30 13:20:22

您是否尝试过设置 EnableAutoSelect = false ?当我将其保留为默认设置时,调用返回所有记录。

Have you tried setting EnableAutoSelect = false? When I left this on the default setting, the call returned all records.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文