117.info
人生若只如初见

如何在C#中实现SQL Server的分页查询

在C#中实现SQL Server的分页查询,可以使用以下几种方法:

  1. 使用ROW_NUMBER()函数:
using System;
using System.Data.SqlClient;

namespace SqlServerPagination
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "your_connection_string";
            int pageNumber = 1;
            int pageSize = 10;

            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();

                string sql = $@"
                    SELECT * FROM (
                        SELECT *, ROW_NUMBER() OVER (ORDER BY Id) AS RowNumber
                        FROM YourTable
                    ) AS PagedTable
                    WHERE RowNumber BETWEEN ((@PageNumber - 1) * @PageSize + 1) AND (@PageNumber * @PageSize)";

                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.Parameters.AddWithValue("@PageNumber", pageNumber);
                    command.Parameters.AddWithValue("@PageSize", pageSize);

                    using (SqlDataReader reader = command.ExecuteReader())
                    {
                        while (reader.Read())
                        {
                            Console.WriteLine($"Id: {reader["Id"]}, Name: {reader["Name"]}");
                        }
                    }
                }
            }
        }
    }
}
  1. 使用OFFSET和FETCH子句(仅适用于SQL Server 2012及更高版本):
using System;
using System.Data.SqlClient;

namespace SqlServerPagination
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "your_connection_string";
            int pageNumber = 1;
            int pageSize = 10;

            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                connection.Open();

                string sql = $@"
                    SELECT *
                    FROM YourTable
                    ORDER BY Id
                    OFFSET (@PageNumber - 1) * @PageSize ROWS
                    FETCH NEXT @PageSize ROWS ONLY";

                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    command.Parameters.AddWithValue("@PageNumber", pageNumber);
                    command.Parameters.AddWithValue("@PageSize", pageSize);

                    using (SqlDataReader reader = command.ExecuteReader())
                    {
                        while (reader.Read())
                        {
                            Console.WriteLine($"Id: {reader["Id"]}, Name: {reader["Name"]}");
                        }
                    }
                }
            }
        }
    }
}

请注意,将your_connection_string替换为你的SQL Server连接字符串,并将YourTable替换为你要查询的表名。这两个示例都使用了分页参数pageNumberpageSize,你可以根据需要调整这些值。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fe157AzsOBwRWDA.html

推荐文章

  • c#和c++有什么区别

    C# 和 C++ 是两种不同的编程语言,它们在许多方面有所不同。以下是它们之间的一些主要区别: 语法:C# 的语法与 Java 更相似,而 C++ 的语法则与 C 更相似。C# 使...

  • c++ string如何转int64

    在 C++ 中,你可以使用 std::stoll(string to long long)函数将一个 std::string 转换为 int64_t
    #include
    #include
    #include int main() { st...

  • c++中this指针的作用是什么

    在C++中,this指针是一个特殊的指针,它在类的成员函数中被隐式使用,以指向调用该成员函数的对象。this指针是一个常量指针,它不能被修改。
    this指针的主要...

  • c++如何实现反射

    C++ 本身并不直接支持反射,但是我们可以通过一些技术手段来模拟实现反射的功能。下面是一个简单的示例,展示了如何在 C++ 中使用类型信息和函数指针来模拟反射:...

  • C#如何调用SQL Server的视图和函数

    在C#中,你可以使用ADO.NET或Entity Framework等技术来调用SQL Server的视图和函数。这里我将给出一个使用ADO.NET调用SQL Server视图和函数的示例。
    首先,...

  • 在C#中使用SQL Server的安全性措施

    在C#中使用SQL Server时,确保数据库连接和查询的安全性非常重要 参数化查询:避免SQL注入攻击。使用参数化查询可以确保用户输入被当作参数值而不是SQL代码的一部...

  • C#中如何进行SQL Server数据库备份

    在C#中,可以使用SMO(SQL Server Management Objects)库来执行SQL Server数据库的备份操作 首先,确保已安装了Microsoft SQL Server Management Objects。你可...

  • 如何在C#中实现SQL Server的错误处理

    在C#中实现SQL Server的错误处理,你可以使用try-catch语句来捕获异常,并根据异常类型进行相应的处理
    using System;
    using System.Data.SqlClient; c...