- 深入浅出:使用Spring Boot实现AOP切面编程
一休哥助手
javaspringboot后端java
目录引言AOP概述AOP的定义与核心概念AOP的优势SpringBoot中的AOP实现SpringAOP与AspectJ依赖配置AOP的工作原理
- Spring—AOP
hitmengfanchao
云计算与软件服务#Spring框架springjava后端云计算
目录1.AOP中的基本概念2.Spring中建立AOP应用的步骤2.1.添加依赖2.2.启用AspectJ注解支持2.3.定义切面2.4.定义切点2.5.定义通知方法2.6.编写业务类2.7.运行应用并测试3.@within注解4.AOP的优点面向方面编程(Aspect-OrientedProgramming,简称AOP)是一种编程范式,旨在通过分离横切关注点(cross-cuttingconce
- AOP面向切面编程
科马
javaspringjava后端
AOP面向切面编程如何理解面向切面编程举例理解:核心概念:SpringAOP两种配置风格基于注解的`@AspectJ`风格基于XML的Schema风格代理机制JDK动态代理CGLIB代理编程方式创建代理配置AspectJ加载时织入如何理解面向切面编程面向切面编程(Aspect-OrientedProgramming,简称AOP)是一种编程范式,它允许开发者将横切关注点(如日志记录、事务管理等)与业
- AOP(面向切面编程)
买完可乐
spring
1.AOP是什么AOP是面向切面编程,能够让我们在不影响原有功能的前提下,为软件横向扩展功能2.搭建SpringAOP使用aspect实现aop的基本步骤:1.新建maven项目2.加入依赖(1)spring依赖(2)aspectj依赖(3)junit单元测试3.创建目标类:接口和他的实现类。要做的是给类中的方法增加功能4.创建切面类:普通类(1)在类的上面加入@Aspect(2)在类中定义方法,
- Spring AOP中的动态代理:JDK动态代理和CGLIB动态代理
裘马轻狂大帅
静态代理模式 所谓静态代理就是AOP框架会在编译阶段生成AOP代理类,因此也称为编译时增强。ApsectJ是静态代理的实现之一,也是最为流行的。静态代理由于在编译时就生成了代理类,效率相比动态代理要高一些。AspectJ可以单独使用,也可以和Spring结合使用。动态代理模式 与静态代理不同,动态代理就是说AOP框架不会去修改编译时生成的字节码,而是在运行时在内存中生成一个AOP代理对象,这个AO
- day07 Spring 事务与集成 MyBatis
灰灰.X
mybatisspringjava
理解AOP是什么,为什么使用AOP,Spring与它是什么关系。AOP是一种面向切面(where,when,what)编程思想想给某些类的某些方法加功能,不用去修改其代码,只要编写配置即可,底层最终使用动态代理帮我们加功能和方法,以后在写多个方法的时候,出现相同的代码的时候,考虑使用AOP来解决spring是AOP思想之一,实际使用的时候需要添加spring-aop和aspectjweaver两个
- Spring——AOP面向切面编程&SpringAOP与AspectJ比较
七海健人
Spring框架springjava
最近跟着源码研究了下Spring使用三级缓存处理循环依赖的原理,里面涉及到SpringAOP的概念;本篇介绍AOP相关的知识点,AOP下的概念名词比较多,尽量使用通俗的概念来逐个解释,内容包括:对AOP(面向切面编程)的理解、AOP下的名词概念、SpringAOP与AspectJ的比较等;这部分知识对于学习Spring框架或者面试,都非常重要,需要掌握;1.到底什么是AOP(面向切面编程)?乍一看
- Maven项目中Allure和AspectJ的配置及测试执行(常见报错解决方法)
杰哥的编程世界
java接口自动化测试mavenjava
Maven项目中Allure和AspectJ的配置及测试执行在自动化测试领域,Allure和AspectJ是两个非常有用的工具。Allure提供了丰富的测试报告,而AspectJ则允许我们以声明式的方式编写横切关注点,如日志记录、事务管理等。本文将指导您如何在Maven项目中配置这两个工具,并使用MavenSurefire插件来执行测试用例。1.添加依赖首先,我们需要在pom.xml文件中添加Al
- aop或拦截器获取鉴权注解信息
ldj2020
javajava鉴权
1.AOP方式packagecom.dj.springboot.study.aspect;importcom.dj.springboot.study.annotation.RolePermission;importorg.aspectj.lang.ProceedingJoinPoint;importorg.aspectj.lang.annotation.Around;importorg.aspec
- 2018-09-20
whIteKi
今天学习了spring的aopaspectjdbcjdbc中的transaction应用,这样的调用mysql我还是喜欢php直接了当,通过jdbc调用可以很方便切换到其他数据库,但是目前调用起来还是有点麻烦,不过还是很有条理,每个模块都做自己的事情,这样就不用重新去一个个看他是怎么调用的。目前还没有理解透彻,明天再去温习一下
- 强悍的Spring之AOP注解使用
你呀不牛
Spring中使用注解方式实现AOP,采用@AspectJ方式实现,首先确定需要切入的方法,也就是连接点@ServicepublicclassUserServiceMethod{publicvoidadd(Stringname){System.out.println("UserServiceMethodaddnameis:"+name);}}开发切面有了连接点,还需要切面通过切面描述AOP其他信息
- Android Aspectj 简单实战
菜鸟何时起飞
第一步创建注解@Retention(RetentionPolicy.RUNTIME)//注解保留至运行时@Target({ElementType.METHOD,ElementType.CONSTRUCTOR})//声明注解作用在方法上面public@interfaceSingleClick{/*点击间隔时间*/longvalue()default2000;}第二步创建PointCut@Aspect
- Spring使用AspectJ开发AOP
小波同学
简介AspectJ是一个基于Java语言的AOP框架,它扩展了Java语言。Spring2.0以后,新增了对AspectJ方式的支持,新版本的Spring框架,建议使用AspectJ方式开发AOP。使用AspectJ开发AOP通常有两种方式:基于XML的声明式。基于Annotation的声明式。@AspectJ是AspectJ1.5以后新增的功能,通过JDK5注解技术,允许直接在Bean类中定义切
- spring AspectJ测试类
2d6b5ee3a71c
拦截com.web包及子包下面的所有方法@Aspect@ConfigurationpublicclassTestAspect{//拦截com.web包及子包下面的所有方法@Pointcut("execution(*com.web..*.*(..))")publicvoidpointcut(){}@Around(value="pointcut()")publicObjectdeal(Proceedi
- Spring Aop:三、使用 AspectJ 框架实现 Spring AOP
weihy
本文参考实验楼教程:https://www.shiyanlou.com/courses/578/learning/?id=1940AspectJ是基于注解(Annotation)的,所以需要JDK5.0版本以上。本文实验环境延用之SpringAop:一、四种advice的实验环境。AspectJ支持的注解类型如下:@Before@After@AfterReturning@AfterThrowing
- Spring Security (1)
Slahser2c
SpringSecurity模块划分ACL支持通过访问控制列表(accesscontrollist,ACL)为域对象提供安全性切面(Aspects)一个很小的模块,当使用SpringSecurity注解时,会使用基于AspectJ的切面,而不是使用标准的SpringAOPCAS客户端(CASClient)提供Jasig的中心认证服务(CentralAuthenticationService,CAS
- android AOP笔记
winxx
一,接入AspectJ是Eclipse出品的Aop框架,可以帮助我们进行很方便的Aop编程。在Eclipse中已经有AJDT插件集成了AspectJ编译器的使用和关键字的声明。但是在AndroidStudio中没有这样的官方插件。在androidstudio进行aspetj接入,试过几个方案,以下方案比较靠谱,只要进行相应Gradle配置:https://fernandocejas.com/blo
- Spring AOP实现原理分析
Zal哥哥
Spring的核心是IOC与AOP,IOC主要是依赖关系的管理,依赖查询,依赖注入,在之前bean的生命周期文章中已经对bean的生命周期做了相对多的分析,这里以前探讨下AOP的实现原理。关键类AspectJAwareAdvisorAutoProxyCreatorSpring启动时的beanPostProcessor,bean生命周期中经常可以看到beanPostProcessor在起作用,AOP
- (一)Spring 核心之面向切面编程(AOP)—— 配置及使用
流华追梦
SpringspringSpringAOPAspectJAOP动态织入静态织入pointcut
目录一.前言二.如何理解AOP2.1.AOP是什么2.2.AOP术语2.3.SpringAOP和AspectJ是什么关系2.3.1.AspectJ是什么2.3.2.SpringAOP和AspectJ是什么关系2.3.3.动态织入和静态织入三.AOP的配置方式3.1.XMLSchema配置方式3.2.AspectJ注解方式3.2.1.接口使用JDK代理3.2.2.非接口使用CGLIB代理四.总结4.
- 26,Spring Boot中使用AOP统一处理Web请求日志
滔滔逐浪
1,引入jarorg.springframework.bootspring-boot-starter-aop2,写web日志类packagecom.nvli.chapter10;importorg.aspectj.lang.JoinPoint;importorg.aspectj.lang.annotation.AfterReturning;importorg.aspectj.lang.annota
- 基于注解的SpringAOP源码解析(三)
Java学习录
注意,读完本篇文章需要很长很长时间在之前的2篇文章:AOP源码分析(一)AOP源码分析(二)中,我们搭建了SpringAOP源码分析的环境,介绍了@EnableAspectJAutoProxy注解和postProcessBeforeInstantiation方法是如何加载所有增强的。本篇文章则将描述一下AOP中剩余的实现逻辑postProcessAfterInitialization这个方法是在b
- AOP For Android -基于AspectJ
信仰在空中zh
本文旨在帮助Andoird开发者快速实现AOP开发,少走弯路欢迎点赞和收藏。网上关于AspectJ的介绍已经很多了,本文就不做过多介绍了。有兴趣的同学可以参考以下链接,感谢大神分享自定义注解学习:https://www.cnblogs.com/peida/archive/2013/04/26/3038503.htmlAspectJ自己去找找吧!网上文章一堆一堆的先简单说一下需求吧在开发的时候,我们
- execution()函数
微凉归期
7-日常工作总结springaop
Aspectj切入点语法定义在使用spring框架配置AOP的时候,不管是通过XML配置文件还是注解的方式都需要定义pointcut”切入点”例如定义切入点表达式execution(*com.sample.service.impl..*.*(..))execution()是最常用的切点函数,其语法如下所示:整个表达式可以分为五个部分:execution():表达式主体。第一个*号:表示返回类型,*
- AOP之JoinPoint.getSignature()
@lihewei
java开发语言
AOP之JoinPoint.getSignature()aop的JoinPoint类:用来获取代理类和被代理类的信息。joinPoint.getSignature()返回的对象有以下方法packageorg.aspectj.lang;publicinterfaceSignature{StringtoString();StringtoShortString();StringtoLongString(
- (基于xml配置Aop)学习Spring的第十五天
y3131954546
学习springjava
一.SpringAop编程简介再详细点,如下二.基于xml配置Aop解决proxy相关问题解决问题开始用xml配置AOP导入pom坐标org.aspectjaspectjweaver1.9.6由于2做过,我们直接展示3,4这是一个基本的对show1()增强的案例上面这段代码表示对show1()进行前置增强-->
- 更快!更高效!启动优化框架Alpha完全解析
积木zz
背景启动优化,其实就是优化从点击icon到主页面展示这个过程的速度,让主界面尽量快的展现在用户面前。所以我们要做的就是找到那些耗时操作,并将其优化。怎么找到?一般分成两个场景:1、线下(debug)场景在应用的开发阶段,我们一般通过AOP进行函数的耗时统计,通过aspectj库可以很方便的将代码插入到函数内部,从而统计到每个方法的耗时时间。或者直接通过AndroidStudio自带的Profile
- Spring-mybatis
两仪式quq
springmybatis
怎样通过Spring整合Mybatis来实现业务目录1.导入依赖junitjunit3.8.1testmysqlmysql-connector-java8.0.33org.mybatismybatis3.5.13org.springframeworkspring-webmvc6.0.13org.springframeworkspring-jdbc6.0.13org.aspectjaspectjwe
- 基于spring aop的dubbo异常统一处理
0X码上链
金融技术分布式技术dubborpc
dubbo统一异常处理,调用方只显示封装后的异常。1、返回封装后的Exception2、返回封装后的统一返回信息importorg.aspectj.lang.annotation.AfterThrowing;importorg.aspectj.lang.annotation.Aspect;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;im
- springboot项目注解限制接口访问次数
lowkey港
1.导包net.jodahexpiringmap0.5.102.定义注解packagecom.kc.framework.aspectj.lang.annotation;importjava.lang.annotation.*;/***@ClassNameLimitRequest定义一个切面,执行方法前去ExpiringMap查询该IP在规定时间内请求了多少次,如超过次数则直接返回请求失败。*@Au
- Spring5框架基础详解(四) (AOP概念、AOP术语、AOP底层原理、JDK动态代理实现、AOP操作)
大黄烽
springjavaspring代理模式xml
文章目录一、什么是AOP二、AOP术语三、AOP底层原理四、AOP(JDK动态代理实现)五、AOP操作5.1AOP操作(基于AspectJ注解方式)5.2完全注解开发一、什么是AOP面向切面编程,不通过修改源代码方式,在主干功能里面添加新功能。二、AOP术语1.连接点:类里面哪些方法可以被增强,这些方法称为连接点2.切入点:实际被真正增强的方法,称为切入点3.通知(增强):(1)实际增强的逻辑部分
- 分享100个最新免费的高匿HTTP代理IP
mcj8089
代理IP代理服务器匿名代理免费代理IP最新代理IP
推荐两个代理IP网站:
1. 全网代理IP:http://proxy.goubanjia.com/
2. 敲代码免费IP:http://ip.qiaodm.com/
120.198.243.130:80,中国/广东省
58.251.78.71:8088,中国/广东省
183.207.228.22:83,中国/
- mysql高级特性之数据分区
annan211
java数据结构mongodb分区mysql
mysql高级特性
1 以存储引擎的角度分析,分区表和物理表没有区别。是按照一定的规则将数据分别存储的逻辑设计。器底层是由多个物理字表组成。
2 分区的原理
分区表由多个相关的底层表实现,这些底层表也是由句柄对象表示,所以我们可以直接访问各个分区。存储引擎管理分区的各个底层
表和管理普通表一样(所有底层表都必须使用相同的存储引擎),分区表的索引只是
- JS采用正则表达式简单获取URL地址栏参数
chiangfai
js地址栏参数获取
GetUrlParam:function GetUrlParam(param){
var reg = new RegExp("(^|&)"+ param +"=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r!=null
- 怎样将数据表拷贝到powerdesigner (本地数据库表)
Array_06
powerDesigner
==================================================
1、打开PowerDesigner12,在菜单中按照如下方式进行操作
file->Reverse Engineer->DataBase
点击后,弹出 New Physical Data Model 的对话框
2、在General选项卡中
Model name:模板名字,自
- logbackのhelloworld
飞翔的马甲
日志logback
一、概述
1.日志是啥?
当我是个逗比的时候我是这么理解的:log.debug()代替了system.out.print();
当我项目工作时,以为是一堆得.log文件。
这两天项目发布新版本,比较轻松,决定好好地研究下日志以及logback。
传送门1:日志的作用与方法:
http://www.infoq.com/cn/articles/why-and-how-log
上面的作
- 新浪微博爬虫模拟登陆
随意而生
新浪微博
转载自:http://hi.baidu.com/erliang20088/item/251db4b040b8ce58ba0e1235
近来由于毕设需要,重新修改了新浪微博爬虫废了不少劲,希望下边的总结能够帮助后来的同学们。
现行版的模拟登陆与以前相比,最大的改动在于cookie获取时候的模拟url的请求
- synchronized
香水浓
javathread
Java语言的关键字,可用来给对象和方法或者代码块加锁,当它锁定一个方法或者一个代码块的时候,同一时刻最多只有一个线程执行这段代码。当两个并发线程访问同一个对象object中的这个加锁同步代码块时,一个时间内只能有一个线程得到执行。另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块。然而,当一个线程访问object的一个加锁代码块时,另一个线程仍然
- maven 简单实用教程
AdyZhang
maven
1. Maven介绍 1.1. 简介 java编写的用于构建系统的自动化工具。目前版本是2.0.9,注意maven2和maven1有很大区别,阅读第三方文档时需要区分版本。 1.2. Maven资源 见官方网站;The 5 minute test,官方简易入门文档;Getting Started Tutorial,官方入门文档;Build Coo
- Android 通过 intent传值获得null
aijuans
android
我在通过intent 获得传递兑现过的时候报错,空指针,我是getMap方法进行传值,代码如下 1 2 3 4 5 6 7 8 9
public
void
getMap(View view){
Intent i =
- apache 做代理 报如下错误:The proxy server received an invalid response from an upstream
baalwolf
response
网站配置是apache+tomcat,tomcat没有报错,apache报错是:
The proxy server received an invalid response from an upstream server. The proxy server could not handle the request GET /. Reason: Error reading fr
- Tomcat6 内存和线程配置
BigBird2012
tomcat6
1、修改启动时内存参数、并指定JVM时区 (在windows server 2008 下时间少了8个小时)
在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数:
window下, 在catalina.bat最前面
set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms5
- Karam与TDD
bijian1013
KaramTDD
一.TDD
测试驱动开发(Test-Driven Development,TDD)是一种敏捷(AGILE)开发方法论,它把开发流程倒转了过来,在进行代码实现之前,首先保证编写测试用例,从而用测试来驱动开发(而不是把测试作为一项验证工具来使用)。
TDD的原则很简单:
a.只有当某个
- [Zookeeper学习笔记之七]Zookeeper源代码分析之Zookeeper.States
bit1129
zookeeper
public enum States {
CONNECTING, //Zookeeper服务器不可用,客户端处于尝试链接状态
ASSOCIATING, //???
CONNECTED, //链接建立,可以与Zookeeper服务器正常通信
CONNECTEDREADONLY, //处于只读状态的链接状态,只读模式可以在
- 【Scala十四】Scala核心八:闭包
bit1129
scala
Free variable A free variable of an expression is a variable that’s used inside the expression but not defined inside the expression. For instance, in the function literal expression (x: Int) => (x
- android发送json并解析返回json
ronin47
android
package com.http.test;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import
- 一份IT实习生的总结
brotherlamp
PHPphp资料php教程php培训php视频
今天突然发现在不知不觉中自己已经实习了 3 个月了,现在可能不算是真正意义上的实习吧,因为现在自己才大三,在这边撸代码的同时还要考虑到学校的功课跟期末考试。让我震惊的是,我完全想不到在这 3 个月里我到底学到了什么,这是一件多么悲催的事情啊。同时我对我应该 get 到什么新技能也很迷茫。所以今晚还是总结下把,让自己在接下来的实习生活有更加明确的方向。最后感谢工作室给我们几个人这个机会让我们提前出来
- 据说是2012年10月人人网校招的一道笔试题-给出一个重物重量为X,另外提供的小砝码重量分别为1,3,9。。。3^N。 将重物放到天平左侧,问在两边如何添加砝码
bylijinnan
java
public class ScalesBalance {
/**
* 题目:
* 给出一个重物重量为X,另外提供的小砝码重量分别为1,3,9。。。3^N。 (假设N无限大,但一种重量的砝码只有一个)
* 将重物放到天平左侧,问在两边如何添加砝码使两边平衡
*
* 分析:
* 三进制
* 我们约定括号表示里面的数是三进制,例如 47=(1202
- dom4j最常用最简单的方法
chiangfai
dom4j
要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http://nchc.dl.sourceforge.net/sourceforge/dom4j/dom4j-1.6.1.zip
解开后有两个包,仅操作XML文档的话把dom4j-1.6.1.jar加入工程就可以了,如果需要使用XPath的话还需要
- 简单HBase笔记
chenchao051
hbase
一、Client-side write buffer 客户端缓存请求 描述:可以缓存客户端的请求,以此来减少RPC的次数,但是缓存只是被存在一个ArrayList中,所以多线程访问时不安全的。 可以使用getWriteBuffer()方法来取得客户端缓存中的数据。 默认关闭。 二、Scan的Caching 描述: next( )方法请求一行就要使用一次RPC,即使
- mysqldump导出时出现when doing LOCK TABLES
daizj
mysqlmysqdump导数据
执行 mysqldump -uxxx -pxxx -hxxx -Pxxxx database tablename > tablename.sql
导出表时,会报
mysqldump: Got error: 1044: Access denied for user 'xxx'@'xxx' to database 'xxx' when doing LOCK TABLES
解决
- CSS渲染原理
dcj3sjt126com
Web
从事Web前端开发的人都与CSS打交道很多,有的人也许不知道css是怎么去工作的,写出来的css浏览器是怎么样去解析的呢?当这个成为我们提高css水平的一个瓶颈时,是否应该多了解一下呢?
一、浏览器的发展与CSS
- 《阿甘正传》台词
dcj3sjt126com
Part Ⅰ:
《阿甘正传》Forrest Gump经典中英文对白
Forrest: Hello! My names Forrest. Forrest Gump. You wanna Chocolate? I could eat about a million and a half othese. My momma always said life was like a box ochocol
- Java处理JSON
dyy_gusi
json
Json在数据传输中很好用,原因是JSON 比 XML 更小、更快,更易解析。
在Java程序中,如何使用处理JSON,现在有很多工具可以处理,比较流行常用的是google的gson和alibaba的fastjson,具体使用如下:
1、读取json然后处理
class ReadJSON
{
public static void main(String[] args)
- win7下nginx和php的配置
geeksun
nginx
1. 安装包准备
nginx : 从nginx.org下载nginx-1.8.0.zip
php: 从php.net下载php-5.6.10-Win32-VC11-x64.zip, php是免安装文件。
RunHiddenConsole: 用于隐藏命令行窗口
2. 配置
# java用8080端口做应用服务器,nginx反向代理到这个端口即可
p
- 基于2.8版本redis配置文件中文解释
hongtoushizi
redis
转载自: http://wangwei007.blog.51cto.com/68019/1548167
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件。采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务。下面是Redis2.8.9的配置文
- 第五章 常用Lua开发库3-模板渲染
jinnianshilongnian
nginxlua
动态web网页开发是Web开发中一个常见的场景,比如像京东商品详情页,其页面逻辑是非常复杂的,需要使用模板技术来实现。而Lua中也有许多模板引擎,如目前我在使用的lua-resty-template,可以渲染很复杂的页面,借助LuaJIT其性能也是可以接受的。
如果学习过JavaEE中的servlet和JSP的话,应该知道JSP模板最终会被翻译成Servlet来执行;而lua-r
- JZSearch大数据搜索引擎
颠覆者
JavaScript
系统简介:
大数据的特点有四个层面:第一,数据体量巨大。从TB级别,跃升到PB级别;第二,数据类型繁多。网络日志、视频、图片、地理位置信息等等。第三,价值密度低。以视频为例,连续不间断监控过程中,可能有用的数据仅仅有一两秒。第四,处理速度快。最后这一点也是和传统的数据挖掘技术有着本质的不同。业界将其归纳为4个“V”——Volume,Variety,Value,Velocity。大数据搜索引
- 10招让你成为杰出的Java程序员
pda158
java编程框架
如果你是一个热衷于技术的
Java 程序员, 那么下面的 10 个要点可以让你在众多 Java 开发人员中脱颖而出。
1. 拥有扎实的基础和深刻理解 OO 原则 对于 Java 程序员,深刻理解 Object Oriented Programming(面向对象编程)这一概念是必须的。没有 OOPS 的坚实基础,就领会不了像 Java 这些面向对象编程语言
- tomcat之oracle连接池配置
小网客
oracle
tomcat版本7.0
配置oracle连接池方式:
修改tomcat的server.xml配置文件:
<GlobalNamingResources>
<Resource name="utermdatasource" auth="Container"
type="javax.sql.DataSou
- Oracle 分页算法汇总
vipbooks
oraclesql算法.net
这是我找到的一些关于Oracle分页的算法,大家那里还有没有其他好的算法没?我们大家一起分享一下!
-- Oracle 分页算法一
select * from (
select page.*,rownum rn from (select * from help) page
-- 20 = (currentPag