首页 > 数据库 > SQL Server > 正文

生成多字段排序分页的SQL的通用类

2024-08-31 00:45:38
字体:
来源:转载
供稿:网友
如果的单一字段排序分页,现在有很多的存储过程和SQL语句,分页的时候,只取pageSize的记录,可遇见的问题是:
这个单一字段必须是唯一的
这个字段必须是可以被排序的
不支持多字段排序
针对这一问题,我用C#做了一个类,解决以上的对多字段排序分页和每次都取pageSize条记录的问题 先看看代码: 
代码如下:

using System; 
using System.Collections.Specialized; 
namespace web 

    /// <summary> 
    /// MultiOrderPagerSQL 的摘要说明 
    /// </summary> 
    public class MultiOrderPagerSQL 
    { 
        private NameValueCollection orders = new NameValueCollection(); 
        private string table_; 
        private string where_="";//1=1 and 2=2 的格式 
        private string outfields_; 
        private int nowPageIndex_=0; 
        private int pagesize_=0; 
        private string sql_;//要返回的SQL 
        public MultiOrderPagerSQL() 
        { 
        } 
        /****************方法*******************/ 
        public void addOrderField(string field, string direction) 
        { 
            orders.Add(field, direction); 
        } 
        public string getSQL() 
        { 
            //排序字段 
            string orderList="";//用户期望的排序 
            string orderList2 = "";//对用户期望的排序的反排序 
            string orderList3 = "";//用户期望的排序,去掉了前缀.复合查询里的外层的排序不能是类似这样的table1.id,要去掉table1.。 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表