【自然框架】QuickPagerSQL——专门生成分页用的SQL的类库

简介: 分享一个生成分页用SQL的函数库     一般一提到分页,大家就会想到存储过程,而大多数情况都是在存储过程里面拼接SQL,我觉得与其在存储过程里面拼接,还不如写个程序来拼接。这样更便于维护,而且效率也不差多少。

   分享一个生成分页用SQL的函数库

 

  一般一提到分页,大家就会想到存储过程,而大多数情况都是在存储过程里面拼接SQL,我觉得与其在存储过程里面拼接,还不如写个程序来拼接。这样更便于维护,而且效率也不差多少。

 

  所以我就写了这个类库—— QuickPagerSQL


  一开始这个功能是在QuickPager分页控件内部的,但是放在一起的话,违反了单一职责。所以把它独立了出来。现在QuickPagerSQL是一个独立的类库,可以单独调用。

 

  他的目的很明确,就是根据已知条件,依据分页算法,来拼接需要的SQL。

 

  需要设置的属性有:表名/视图名、要显示的字段名、排序字段及方式、主键字段名、查询条件、一页的记录数、总记录数、分页算法。

 

  然后依据选择的分页算法生成相应的SQL。而这个SQL有两类,一类是获取总记录数;一类是读取指定页号的SQL。

 

  为了提高效率,读取记录的SQL又分为了三个,读取首页的记录、读取最后一页的记录、读取指定页号的记录。

 

  其实只需要一个“读取指定页号的记录”的SQL就可以了,那么为什么还要一个读取首页的SQL呢?这个是为了提高效率。

 

  因为一些数情况下,读取第一页可以用 select top PageSize * 的方式来获取。这个既简单,效率也是很高的(相同条件下)。而首页还负责一个任务,那就是统计总记录数,而这个是比较占用时间的,那么在显示首页的时候,尽量优化一下是很必要的。所以就单独设置了一个读取首页记录的SQL。

 

  那么读取最后一页记录的SQL又是什么目的呢?这个主要是为了修改颠倒top的一个bug。用过颠倒top的都会发现有一个郁闷的地方,那就是在显示最后一页的时候,如果记录数不够pageSize的时候,也会显示pagesize条记录。这是在颠倒的时候出现的问题,本身没有什么解决的方法(目前我还没有找到,不知道哪位高人能够解决)。于是我就单独做了一个读取最后一页记录的SQL。用这个SQL来修正颠倒top的这个bug。

 

  主要就是这样了。

 

  这个并不是代码生成器,而是要在运行时动态生成SQL的。

 

  目前提供了多种分页算法,Max、颠倒Top、表变量、Row_Number等。而且还可以扩充。见下面的类图:

 

 

  使用方法:这个就很简单了,设置属性,调用函数就可以了。

 

img_405b18b4b6584ae338e0f6ecaf736533.gif 代码
///   <summary>
    
///  生成分页用的SQL的演示
    
///   </summary>
     public   partial   class  PagerSQLPage : System.Web.UI.Page
    {
        
protected   void  Page_Load( object  sender, EventArgs e)
        {

        }

        
protected   void  btn_Create_Click( object  sender, EventArgs e)
        {
            
// 生成分页用SQL
             string  tableName  =   this .txt_TableName.TextTrimNone ;
            
string  orderByColumns  =   this .txt_OrderByColumns.TextTrimNone ;
            
string  PKColumn  =   this .txt_PKColumn.TextTrimNone ;
            
string  tableQuery  =   this .txt_Query.TextTrimNone ;
            
string  showColumns  =   this .txt_ShowColumns.TextTrimNone ;
            
string  pageIndex  =   this .txt_Index.TextTrimNone;
            
string  pageCount  =   this .txt_PageCount.TextTrimNone;

            
if  ( ! Functions.IsInt(pageIndex))
            {
                Functions.PageRegisterAlert(Page, 
" 页号必须是整数! " );
                
return ;
            }

            QuickPagerSQL sql 
=   new  QuickPagerSQL();
            sql.TableName 
=  tableName;                       // 表名或者视图名
            sql.TableShowColumns  =  showColumns;              // 要显示的字段
            sql.TablePKColumn  =  PKColumn;                    // 主键
            sql.TableOrderByColumns  =  orderByColumns;        // 排序字段
            sql.TableQuery  =  tableQuery;                     // 查询条件
          
            sql.PageCount 
=   int .Parse(pageCount);            // 一页的记录数

            
// 选择一种分页算法
            sql.SetPagerSQLKind  =  (PagerSQLKind)Int32.Parse( this .lst_Kind.SelectedValue) ;

            
// 拼接SQL;
            sql.CreateSQL();

            
// 统计总记录数的SQL
             this .txt_SQL1.Text  =  sql.GetRecordCountSQL;

            
// 实际中需要用上面的SQL到数据库里统计,这里“虚构”一个总记录数。
            sql.RecordCount  =   200 ;


            
// 获取指定页数据的SQL
             this .txt_SQL2.Text  =  sql.GetSQLByPageIndex( int .Parse(pageIndex));


        }
    }

 

 

 

  直通车:http://demo.naturefw.com/Nonline/QuickPager/PagerSQL/PagerSQLPage.aspx

  在线演示:http://demo.naturefw.com/Nonline/QuickPager/default.aspx

  下载:http://www.naturefw.com/down/List1.aspx  

 

  目前分页控件还没有分离出来,所以还都在自然框架源码的大解决方案里。

 

  QuickPagerSQL的位置:

 

  _UDRM 项目里的 SQL_Pager 文件夹,这里的代码都是。

 

  QuickPager分页控件的位置:

 

  _WebControls项目里的 Pager、Pager_UI两个文件夹。

 

  目前正在考虑如何拆分这个大的解决方案。

 

 


 

相关文章
|
3月前
|
SQL 数据采集 自然语言处理
NL2SQL之DB-GPT-Hub<详解篇>:text2sql任务的微调框架和基准对比
NL2SQL之DB-GPT-Hub<详解篇>:text2sql任务的微调框架和基准对比
|
2月前
|
SQL 监控 安全
Flask 框架防止 SQL 注入攻击的方法
通过综合运用以上多种措施,Flask 框架可以有效地降低 SQL 注入攻击的风险,保障应用的安全稳定运行。同时,持续的安全评估和改进也是确保应用长期安全的重要环节。
173 71
|
1月前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
190 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
5月前
|
SQL Java 数据库
建模底层逻辑问题之ORM框架建模中,执行SQL的过程中被抽象和组织是如何实现的
建模底层逻辑问题之ORM框架建模中,执行SQL的过程中被抽象和组织是如何实现的
|
4天前
|
SQL 分布式计算 Java
Spark SQL向量化执行引擎框架Gluten-Velox在AArch64使能和优化
本文摘自 Arm China的工程师顾煜祺关于“在 Arm 平台上使用 Native 算子库加速 Spark”的分享,主要内容包括以下四个部分: 1.技术背景 2.算子库构成 3.算子操作优化 4.未来工作
|
1月前
|
SQL 安全 Java
除了Flask框架,还有哪些框架能防止SQL注入攻击?
这些框架都在安全方面有着较好的表现,通过它们的内置机制和安全特性,可以有效地降低 SQL 注入攻击的风险。然而,无论使用哪个框架,开发者都需要具备良好的安全意识,正确配置和使用框架提供的安全功能,以确保应用的安全可靠。同时,持续关注安全更新和漏洞修复也是非常重要的。
57 7
|
2月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
2月前
|
SQL 自然语言处理 数据库
XiYan-SQL:一种多生成器集成的Text-to-SQL框架
XiYan-SQL 是一种创新的多生成器集成Text-to-SQL框架,通过M-Schema增强模型对数据库结构的理解,结合ICL与SFT方法提升SQL生成质量和多样性,经实验证明在多个数据集上表现优异,特别是在Spider和SQL-Eval上取得了领先成绩。
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
82 4
|
5月前
|
SQL 关系型数据库 MySQL
SQL中如何实现分页?
【8月更文挑战第3天】SQL中如何实现分页?
188 36