legongju.com
我们一直在努力
2025-01-10 18:27 | 星期五

如何在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.legongju.com/article/99620.html

相关推荐

  • c#数组切片的边界处理

    c#数组切片的边界处理

    在C#中,数组切片是通过指定起始索引和结束索引来获取数组的一部分。为了正确处理边界情况,需要注意以下几点: 起始索引和结束索引应该在数组的有效范围内。如果...

  • 数组切片在c#数据处理中的应用

    数组切片在c#数据处理中的应用

    在C#中,数组切片是一种从现有数组中创建新数组的方法,新数组包含原始数组的一部分元素
    以下是一个简单的示例,说明如何在C#中使用数组切片:
    using ...

  • c#中数组切片的常见错误

    c#中数组切片的常见错误

    在C#中,数组切片是一种从现有数组中获取子数组的方法。然而,在进行数组切片时,可能会遇到一些常见错误。以下是一些常见的错误及其解决方案: 越界错误(Index...

  • c#数组切片的性能优化

    c#数组切片的性能优化

    在C#中,数组切片(slicing)是指从一个较大的数组中提取一部分元素并将其存储在一个新数组中。这种操作在处理大量数据时可能会影响性能。为了优化数组切片的性能...

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

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

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

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

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

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

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

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

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

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

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

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