zoukankan      html  css  js  c++  java
  • sql2000数据库 sql语句C#分页类代码

    using System;
    using System.Data;
    using System.Configuration;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;
    using System.Text;
    using fjt.DBUtility;

    /// <summary>
    /// 分页用sql查询类 http://www.my400800.cn
    /// </summary>
    public class SelectTableDataForPage
    {
        /// <summary>
        /// 构造函数
        /// </summary>
        public SelectTableDataForPage()
        {
            //
            // TODO: Add constructor logic here
            //
        }

        #region  public static int getSelectNowPageCount(string strTableName,string strSqlWhere, int iPageSize) 指定表指定条件总页数取得
        /// <summary>
        /// 指定表指定条件总页数取得
        /// </summary>
        /// <param name="strTableName">表名</param>
        /// <param name="strSqlWhere">查询条件</param>
        /// <param name="iPageSize">每页显示记录数</param>
        /// <returns></returns>
        public static int getSelectNowPageCount(string strTableName, string strSqlWhere, int iPageSize)
        {
            //如果指定每页显示记录数小于0,每页显示记录数10设定
            if (iPageSize <= 0) iPageSize = 10;
            StringBuilder sbSql = new StringBuilder("select count(*) from ");
            sbSql.Append(strTableName);
            if (!string.IsNullOrEmpty(strSqlWhere))
            {
                sbSql.Append(" where 1=1 ").Append(strSqlWhere);

            }
            int RowCount = Convert.ToInt32(SqlHelper.ExecuteScalar(SqlHelper.ConnectionString, CommandType.Text, sbSql.ToString()));
            int pageCount = RowCount % iPageSize > 0 ? RowCount / iPageSize + 1 : RowCount / iPageSize;

            return pageCount;
        }
        #endregion

        #region 取得指定条件指定页码指定排序的表数据 public static DataTable SelectNowPageForDS(string strTableName, string strSelFeilds, string strPk, string strOrderBy, string strWhere, int iNowPage, int iPageSize)
        /// <summary>
        /// 取得指定条件指定页码指定排序的表数据
        /// </summary>
        /// <param name="strTableName">表名</param>
        /// <param name="strSelFeilds">取得字段 多个字段用逗号分开</param>
        /// <param name="strPk">唯一主键</param>
        /// <param name="strOrderBy">排序字段,多个用逗号分开</param>
        /// <param name="strWhere">查询条件</param>
        /// <param name="iNowPage">要取得的页码数据</param>
        /// <param name="iPageSize">当前页码显示记录数量</param>
        /// <returns></returns>
        public static DataTable SelectNowPageForDS(string strTableName, string strSelFeilds, string strPk, string strOrderBy, string strWhere, int iNowPage, int iPageSize)
        {
            //如果指定每页显示记录数小于0,每页显示记录数10设定
            if (iPageSize <= 0) iPageSize = 10;

            //分页用sql取得
            string strExecSql = GetSelectForPageSql(strTableName, strSelFeilds, strPk, strOrderBy, strWhere, iNowPage, iPageSize);
            DataTable dtSel = SqlHelper.ExecuteDataset(SqlHelper.ConnectionString, CommandType.Text, strExecSql).Tables[0];
            return dtSel;
        }
        #endregion

        #region 取得指定条件指定页码指定排序的sql查询语句

        /// <summary>
        /// 取得指定条件指定页码指定排序的sql查询语句
        /// </summary>
        /// <param name="strTableName">表名</param>
        /// <param name="strSelFeilds">取得字段 多个字段用逗号分开</param>
        /// <param name="strPk">唯一主键</param>
        /// <param name="strOrderBy">排序字段,多个用逗号分开</param>
        /// <param name="strWhere">查询条件</param>
        /// <param name="iNowPage">要取得的页码数据</param>
        /// <param name="iPageSize">当前页码显示记录数量</param>
        /// <returns>sql查询语句返回</returns>
        public static string GetSelectForPageSql(string strTableName, string strSelFeilds, string strPk, string strOrderBy, string strWhere, int iNowPage, int iPageSize)
        {

            //如果指定每页显示记录数小于0,每页显示记录数10设定
            if (iPageSize <= 0) iPageSize = 10;

            //拼接后结果
            //http://www.my400800.cn
            //语句形式:
            //        SELECT TOP 页大小 *
            //FROM TestTable
            //WHERE (ID NOT IN
            //          (SELECT TOP 页大小*页数 id
            //         FROM 表
            //         ORDER BY id))
            //ORDER BY ID
            //检索字段内容如果是空 取得所有字段信息
            strSelFeilds = string.IsNullOrEmpty(strSelFeilds) ? "*" : strSelFeilds;

            StringBuilder sbSql = new StringBuilder("");
            sbSql.Append("( SELECT ")
                .AppendLine(strSelFeilds)
                .AppendLine(" FROM ")
                .AppendLine(strTableName);
            //查询条件拼接处理
            if (!string.IsNullOrEmpty(strWhere))
            {
                sbSql.AppendLine(" WHERE  1=1 ").Append(strWhere);
            }
            sbSql.AppendLine(") selForPageTempTable");


            //排序字段sql用字符取得
            string strSqlOrderBy = "";
            if (!string.IsNullOrEmpty(strOrderBy))
            {
                strSqlOrderBy = " ORDER BY " + strOrderBy;

            }

            StringBuilder sbExecSql = new StringBuilder("SELECT ");
            sbExecSql.Append(" TOP ").Append(iPageSize).Append(" ").Append(strSelFeilds).Append(" FROM ").Append(sbSql).Append(" WHERE (").Append(strPk)
                    .Append(" NOT IN ( SELECT TOP ").Append((iNowPage - 1) * iPageSize).Append(" ").Append(strPk).Append(" FROM ").Append(strTableName)
                    .Append(strSqlOrderBy).Append(")) ").AppendLine(strSqlOrderBy);

            return sbExecSql.ToString();
        }


        /// <summary>
        /// 取得指定条件指定页码指定排序的sql查询语句
        /// </summary>
        /// <param name="strTableName">表名</param>
        /// <param name="strPk">唯一主键</param>
        /// <param name="strOrderBy">排序字段,多个用逗号分开</param>
        /// <param name="strWhere">查询条件</param>
        /// <param name="iNowPage">要取得的页码数据</param>
        /// <param name="iPageSize">当前页码显示记录数量</param>
        /// <returns>sql查询语句返回</returns>
        /// <returns>sql查询语句返回</returns>
        public static string GetSelectForPageSql(string strTableName, string strPk, string strOrderBy, string strWhere, int iNowPage, int iPageSize)
        {
            return GetSelectForPageSql(strTableName, null, strPk, strOrderBy, strWhere, iNowPage, iPageSize);
        }

        /// <summary>
        /// 取得指定条件指定页码指定排序的sql查询语句
        /// </summary>
        /// <param name="strTableName">表名</param>
        /// <param name="strPk">唯一主键</param>
        /// <param name="strOrderBy">排序字段,多个用逗号分开</param>
        /// <param name="iNowPage">要取得的页码数据</param>
        /// <param name="iPageSize">当前页码显示记录数量</param>
        public static string GetSelectForPageSql(string strTableName, string strPk, string strOrderBy, int iNowPage, int iPageSize)
        {
            return GetSelectForPageSql(strTableName, null, strPk, strOrderBy, null, iNowPage, iPageSize);
        }
        #endregion

    }

  • 相关阅读:
    Ubuntu14.04手动安装配置jdk sdk ndk ant
    Ubuntu中(桌面或者文件夹)右键鼠标打开终端设置
    C语言中固定长度和不定长度的数组初始化示例
    Algorithm Design——最大公约数、最小公倍数
    Algorithm Design——凸包
    Algorithm Design——判断线段是否相交
    Algorithm Design Everyday——2.查找学生信息
    Algorithm Design——查找
    Algorithm Design——高精度整数四则运算
    Algorithm Design——并查集
  • 原文地址:https://www.cnblogs.com/jishu/p/1940093.html
Copyright © 2011-2022 走看看