java集合
- 格式:pdf
- 大小:539.15 KB
- 文档页数:5
集合的概念java在Java中,集合是一种用于存储对象的容器。
它提供了一系列方法来操作和处理这些对象。
Java中的集合主要分为两大类:Collection和Map。
Collection是一个接口,表示一组对象的容器,它有多个实现类,如List、Set 等。
Collection接口定义了一些常用的操作方法,如添加元素、删除元素、判断元素是否存在等。
List是有序的集合,可以有重复的元素。
常见的List实现类有ArrayList和LinkedList。
Set是无序的集合,不允许有重复的元素。
常见的Set实现类有HashSet和TreeSet。
Map是存储键值对的集合,每个键都是唯一的。
常见的Map实现类有HashMap 和TreeMap。
在使用集合时,首先需要创建集合对象,然后使用add()方法添加元素,使用remove()方法删除元素,使用contains()方法判断元素是否存在等。
也可以使用迭代器(Iterator)遍历集合中的每个元素。
示例代码如下:javaimport java.util.*;public class CollectionExample {public static void main(String[] args) {创建一个List集合List<String> list = new ArrayList<>();添加元素list.add("apple");list.add("banana");list.add("orange");输出集合元素for (String element : list) {System.out.println(element);}删除元素list.remove("banana");判断元素是否存在System.out.println(list.contains("apple")); 输出trueSystem.out.println(list.contains("banana")); 输出false }}上述代码创建了一个List集合,并添加了一些元素。
java中集合的概念Java中的集合是一种非常重要的数据结构,用于存储和操作一组对象。
集合框架包含了许多类和接口,可以方便地进行数据的存储、查询、排序等操作,使得Java程序开发变得更加高效和便捷。
在本文中,我们将逐步介绍Java中集合的概念和用法。
一、集合框架概述Java中的集合框架是一个包含了多个接口和类的层次结构,用于表示和操作一组对象。
集合框架包含了通用的集合接口和实现,以及特定的集合类和接口,如List、Set、Map等。
集合框架的接口和类都是通过泛型实现的,可以存储任意类型的对象,比如基本类型和自定义类型的对象。
二、集合框架的接口Java中的集合框架包含了多个接口,其中包括:1. Collection:代表一组对象的集合,是其他集合接口的父接口。
它定义了一些通用的方法,如添加、删除、迭代等。
2. List:代表有序的集合,其中每个元素都有一个对应的索引。
List允许重复元素出现,并且可以通过索引访问、添加、删除元素。
3. Set:代表无序的集合,其中每个元素都是唯一的。
Set不允许重复的元素出现,可以用来去重。
4. Map:代表一组键值对的集合,其中每个键都是唯一的。
Map 允许多个值对应同一个键,可以用来快速查找和存储数据。
三、集合类的实现Java中的集合类可以通过实现集合接口来实现。
如ArrayList、LinkedList、HashSet、TreeSet、HashMap、TreeMap等都是集合类的实现,我们可以通过这些集合类来方便地实现对一组对象的操作。
例如:1. 使用ArrayList来实现List接口,可以进行元素的添加、删除、查询等操作:List<String> list = new ArrayList<>();list.add("Alice");list.add("Bob");System.out.println(list.get(1));2. 使用HashSet来实现Set接口,可以去重并存储元素:Set<Integer> set = new HashSet<>();set.add(1);set.add(2);set.add(2);System.out.println(set.size());3. 使用HashMap来实现Map接口,可以快速查找并存储数据:Map<String, Integer> hashMap = new HashMap<>(); hashMap.put("Alice", 12);hashMap.put("Bob", 18);System.out.println(hashMap.get("Bob"));四、集合的迭代Java中的集合类都实现了Iterable接口,因此可以使用迭代器来访问集合中的元素。
java集合的定义1. Java集合是一种用于存储和操作一组对象的数据结构。
它提供了一种更高级别的抽象,可以方便地进行添加、删除、查找和遍历操作。
集合可以存储多个对象,并且可以根据需要动态调整大小。
2. Java集合框架是Java编程语言提供的一组接口、类和算法,用于实现各种集合类型。
它包括了List、Set、Queue和Map等常用集合接口,以及它们的具体实现类。
集合框架提供了一种标准化的方式来处理集合,使得开发人员可以更加方便地使用和操作集合。
3. Java集合框架中的每个集合都是通过特定的接口来定义的。
例如,List接口代表了一个有序的集合,可以包含重复的元素。
Set接口代表了一个无序的集合,不允许包含重复的元素。
Queue接口代表了一个先进先出的队列,可以用于实现任务调度和事件处理等场景。
Map接口代表了一组键值对的映射,可以通过键来查找对应的值。
4. 在集合框架中,每个具体的集合类都实现了相应的接口,并提供了一套通用的方法来操作集合。
例如,ArrayList是List接口的一个实现类,它使用数组来存储元素,并提供了一系列方法来添加、删除、查找和遍历列表中的元素。
HashSet是Set接口的一个实现类,它使用哈希表来存储元素,并提供了一套方法来添加、删除和查找集合中的元素。
5. Java集合框架还提供了一些算法和工具类,可以用于对集合进行排序、查找和操作等操作。
例如,Collections类提供了一系列静态方法,可以对集合进行排序、查找和复制等操作。
Arrays类提供了一系列静态方法,可以对数组进行排序、查找和复制等操作。
这些算法和工具类可以大大简化集合的处理过程,并提高开发效率。
总结:Java集合是一种用于存储和操作一组对象的数据结构,它提供了一种更高级别的抽象,可以方便地进行添加、删除、查找和遍历操作。
Java集合框架是Java编程语言提供的一组接口、类和算法,用于实现各种集合类型,并提供了一种标准化的方式来处理集合。
java中集合知识点总结1. Collection接口Collection接口是Java中集合类的基本接口,它定义了一组通用的操作方法,包括添加、删除、查找等操作。
Collection接口有三个主要的子接口:List、Set和Queue。
(1) ListList是一种有序的集合,它允许重复的元素,并且可以按照索引访问元素。
List接口中有常用的实现类:ArrayList、LinkedList和Vector。
其中,ArrayList是基于数组实现的,它支持快速的随机访问和插入操作;LinkedList是基于双向链表实现的,它支持快速的插入和删除操作;Vector是线程安全的类,它支持并发访问。
(2) SetSet是一种不允许重复元素的集合,它用来存储唯一的元素。
Set接口中有常用的实现类:HashSet、LinkedHashSet和TreeSet。
其中,HashSet是基于哈希表实现的,它提供了快速的查找和插入操作;LinkedHashSet是基于哈希表和链表实现的,它保持了元素的插入顺序;TreeSet是基于红黑树实现的,它提供了有序的集合。
(3) QueueQueue是一种先进先出的集合,它用来存储元素,并且支持插入和删除操作。
Queue接口中有常用的实现类:LinkedList和PriorityQueue。
其中,LinkedList可以作为Queue来使用,它支持快速的插入和删除操作;PriorityQueue是基于堆实现的,它提供了优先级队列的功能。
2. Map接口Map接口是Java中的映射表,它用来存储键值对的数据。
Map接口中有常用的实现类:HashMap、LinkedHashMap、TreeMap和Hashtable。
其中,HashMap是基于哈希表实现的,它提供了快速的查找和插入操作;LinkedHashMap是基于哈希表和链表实现的,它保持了键值对的插入顺序;TreeMap是基于红黑树实现的,它提供了有序的映射表;Hashtable是线程安全的类,它支持并发访问。
Java集合系列(⼀):集合的定义及分类1. 集合的定义什么是集合呢?定义:集合是⼀个存放对象的引⽤的容器。
在Java中,集合位于java.util包下。
2. 集合和数组的区别(⾯试常问)提到容器,就会想起数组,那么集合和数组的区别是什么呢?(这⾥是重点,⾯试可能问的⽐较多)1. 数组和集合都是Java中的容器2. 数组的长度是固定的,集合的长度是可变的3. 数组只能存储相同数据类型的数据,这⾥的数据类型可以是基本数据类型,也可以是引⽤类型4. 集合可以存储不同数据类型的对象的引⽤(但⼀般情况下,我们会使⽤泛型来约定只使⽤1种数据类型),但不能存储基本数据类型空⼝⽆凭,我们来点代码配合理解,⾸先,我们看下如下的数组代码:String[] platformArray = new String[3];platformArray[0] = "博客园";platformArray[1] = "掘⾦";platformArray[2] = "微信公众号";platformArray[3] = "个⼈博客";运⾏代码就会发现,platformArray[3] = "个⼈博客";会引发ng.ArrayIndexOutOfBoundsException异常。
⽽使⽤集合时就不存在这个问题,因为集合在声明时不需要指定长度并且长度会根据放⼊元素的多少⽽变化:List<String> platformList = new ArrayList<>();platformList.add("博客园");platformList.add("掘⾦");platformList.add("微信公众号");platformList.add("个⼈博客");观察上⾯声明数组的代码,我们可以推断出下⾯的代码肯定是编译不通过的:String[] platformArray = new String[3];platformArray[0] = "博客园";platformArray[1] = "掘⾦";platformArray[2] = 1;因为数组声明时⽤的是String类型,⽽platformArray[2] = 1;赋值时却使⽤了int类型。
Java中常用的集合类有哪些?它们的使用场景是什么?Java作为目前最为流行的编程语言之一,其优越的面向对象编程思想和强大的类库使其成为了广大编程爱好者和专业开发者的首选语言之一。
在Java开发中,常用的集合类具有广泛的应用场景,可以大大简化我们代码的编写和维护。
在本篇文章中,我们将介绍Java中常用的集合类有哪些,它们的使用场景是什么,以及如何选择合适的集合类来应对各种场景。
一、Java中常用的集合类Java中常用的集合类包括List、Set、Map等,具体如下:1.ListList是Java中最基础和最常用的集合类之一,它是一个有序的集合,可以存储重复的元素。
List提供了一系列的方法用来操作列表中的元素,如添加、删除、获取、修改等。
常见的List有ArrayList 和LinkedList。
2.SetSet是Java中的另一个基础集合类,它是一个无序的集合,不允许存储重复的元素。
Set提供了一系列的方法用来操作集合中的元素,如添加、删除、获取等。
常见的Set有HashSet、TreeSet。
3.MapMap是Java中常用的映射关系集合,它存储键值对,支持通过键来访问值。
Map提供了一系列的方法用来操作映射关系,如添加、删除、获取、修改等。
常见的Map有HashMap、TreeMap、ConcurrentHashMap等。
二、Java中常用集合类的使用场景不同的集合类有不同的使用场景,我们需要根据具体的业务需求来选择合适的集合类。
下面我们来介绍几种常见的使用场景及其对应的集合类。
1.需要随机访问元素的情况:ArrayListArrayList是Java中常用的集合类之一,它支持随机访问,通过索引访问元素的时间复杂度为O(1),是处理元素数量较大的情况下的较好选择。
2.需要频繁插入或删除元素的情况:LinkedListLinkedList是另一个常用的集合类,它支持快速的插入和删除操作,通过节点互相关联实现。
集合面试题java1. 什么是集合?集合是Java中的一个常用数据结构,用来存储一组有序或无序的数据。
它是由一组固定大小的元素构成,可以添加、删除和访问其中的元素。
Java中的集合类被包含在java.util包中。
2. Java中有哪些类型的集合?Java中有三种类型的集合,分别是List、Set和Map。
- List:可以存储有序的元素,可以包含重复的元素。
常见的List类有ArrayList和LinkedList。
- Set:主要用于存放无序、不可重复的元素,不存在索引。
常见的Set类有HashSet和TreeSet。
- Map:用于存储键值对,每个存储的元素包含两部分,即键和值。
常见的Map类有HashMap和TreeMap。
3. ArrayList和LinkedList的区别是什么?ArrayList是基于数组实现的集合,具有一定的随机访问性能,可以快速获取指定位置的元素。
但是它在插入和删除元素时效率相对较低,需要重新排列数组。
而LinkedList是基于链表实现的集合,插入和删除元素时速度比ArrayList要快,但是获取指定位置的元素需要遍历整个链表,效率相对较低。
4. HashSet和TreeSet的区别是什么?HashSet是基于哈希表实现的集合,不保证元素的顺序,具有快速的添加、删除和查找元素的能力。
但是它不支持对元素的有序遍历。
而TreeSet是基于红黑树实现的集合,对元素进行自然排序或者指定排序规则进行排序,可以通过迭代器对元素进行有序的遍历。
5. 什么是迭代器?迭代器是一种遍历集合元素的方式,用于逐个访问集合元素。
它是Java中的一个接口,包含常用的方法,如hasNext()和next()。
Iterator 接口是Java中访问集合元素的标准方式,可以访问所有实现了java.util.Collection接口的集合类。
6. 如何遍历一个集合?Java中提供了三种遍历集合的方式,分别是for-each循环、迭代器和Java 8中的Lambda表达式。
java集合的概念
Java集合是Java语言中的一种数据结构,用于存储和操作一组对象。
它提供了许多接口和类,可以方便地实现各种数据结构,如列表、队列、栈、集合等。
Java集合框架由以下三个主要接口层次结构组成:
1. Collection 接口:表示一组对象,在这个接口中可以定义添加、删除、查找、排序等方法。
2. List 接口:表示一个有序的集合,允许重复元素,并且可以通过索引来访问元素。
3. Set 接口:表示一个无序的集合,不允许重复元素。
除了以上三个主要接口外,Java还提供了Map接口,它表示一个键值对的映射表,其中每个键都唯一对应一个值。
Map接口允许使用键来查找值,并且可以遍历所有的键值对。
在Java集合框架中还有一些其他的类和接口,如Iterator迭代器、Comparator比较器等,它们都是为了方便地操作和管理集合而设计
的。
Java集合框架具有以下几个特点:
1. 高效性:Java集合框架中的数据结构都经过优化,能够高效地存储和操作大量数据。
2. 可扩展性:Java集合框架提供了多种接口和类,可以方便地扩展和定制数据结构。
3. 安全性:Java集合框架中的数据结构都经过严格测试,确保能够正确地处理各种情况。
4. 易用性:Java集合框架提供了简单易用的接口和方法,使得开发人员可以快速地实现各种数据结构。
总之,Java集合是Java语言中非常重要的一部分,它提供了丰富的数据结构和操作方法,为程序员提供了高效、安全、易用的编程工具。
java集合创建方式Java集合是Java中非常重要的数据结构,它提供了一种高效的方式来存储和操作数据。
Java集合框架包含了许多不同类型的集合,如List、Set、Map等等。
下面将介绍Java集合的创建方式。
1. 使用ArrayList创建List集合ArrayList是Java中最常用的List集合实现,它可以动态地添加和删除元素。
以下是使用ArrayList创建List集合的示例代码: ```List<String> list = new ArrayList<String>();list.add('apple');list.add('banana');list.add('orange');```2. 使用HashSet创建Set集合HashSet是Java中最常用的Set集合实现,它可以用来存储唯一的元素。
以下是使用HashSet创建Set集合的示例代码:```Set<String> set = new HashSet<String>();set.add('apple');set.add('banana');set.add('orange');```3. 使用HashMap创建Map集合HashMap是Java中最常用的Map集合实现,它可以用来存储键值对。
以下是使用HashMap创建Map集合的示例代码:```Map<String, String> map = new HashMap<String, String>(); map.put('apple', 'red');map.put('banana', 'yellow');map.put('orange', 'orange');```4. 使用TreeSet创建有序Set集合TreeSet是Java中用于创建有序Set集合的实现。
java集合添加元素的方法Java集合是Java中常用的数据结构,用于存储和操作一组对象。
在Java集合中,添加元素是一种常见的操作。
本文将介绍Java集合中添加元素的方法。
Java集合框架提供了多种集合类型,如List、Set和Map,每种集合类型都有自己特定的添加元素的方法。
1. List集合的添加元素方法:List是有序的集合,可以包含重复元素。
常见的List集合实现类有ArrayList和LinkedList。
- 使用add方法:List集合的add方法可以将元素添加到集合的末尾。
- 使用add(index, element)方法:可以将元素插入到指定位置。
2. Set集合的添加元素方法:Set是无序的集合,不允许包含重复元素。
常见的Set集合实现类有HashSet和TreeSet。
- 使用add方法:Set集合的add方法可以将元素添加到集合中。
- 使用addAll方法:可以将另一个集合中的所有元素添加到当前集合中。
3. Map集合的添加元素方法:Map是键值对的集合,每个元素都包含一个键和一个值。
常见的Map集合实现类有HashMap和TreeMap。
- 使用put方法:Map集合的put方法可以将键值对添加到集合中。
- 使用putAll方法:可以将另一个Map集合中的所有键值对添加到当前集合中。
除了上述常见的添加元素方法,Java集合框架还提供了其他一些特殊的添加元素方法。
4. 使用addAll方法添加多个元素:除了上述提到的addAll方法,Java集合框架还提供了addAll方法的变体,可以一次性添加多个元素。
5. 使用Collections类的nCopies方法添加重复元素:Collections类是Java集合框架的工具类,其中的nCopies方法可以创建一个包含指定元素重复多次的集合。
6. 使用Stream API的collect方法添加元素:Java 8引入了Stream API,其中的collect方法可以将Stream 流中的元素收集到一个新的集合中。
随笔-37 文章 -13 trackbacks -0JAVA 集合小结下面是我自己画的,关系画得没上面好,但我自己看着清楚些还有一张下载来的:我的JAVA 学休息,休息首页新随笔联系聚合管理我的随笔我的评论我的参与最新评论给我留言查看公开留言查看私人留言CSS(3)DB(3)EJBHibernate HTML(3)ibatisJava 基础(11)JS(3)JSP(1)Spring(1)Struts(2)Struts2(1)Swing设计模式(7)2009年3月 (1)2009年2月 (1)2008年8月 (5)2008年6月 (2)2008年5月 (1)2008年4月 (1)2008年3月 (1)2008年2月 (2)2008年1月 (7)2007年12月 (1)2007年11月 (4)1. re: java.util.ConcurrentModifi cationException用remove (index )方法就不会有这种情况--子墨2. re: Oracle 分页SQL 评论内容较长,点击标题查看--软件秀秀3. re: Oracle 分页SQL[未登录]@aegeanselect * from bill_account_book where rownum > 10 这个是明显常用链接留言簿(3)随笔分类随笔档案最新评论几个面试常见问题:1.Q:ArrayList 和Vector 有什么区别?HashMap 和HashTable 有什么区别?A:Vector 和HashTable 是线程同步的(synchronized )。
性能上,ArrayList 和HashMap 分别比Vector 和Hashtable 要好。
2.Q:大致讲解java 集合的体系结构A:List 、Set 、Map 是这个集合体系中最主要的三个接口。
其中List 和Set 继承自Collection 接口。
Set 不允许元素重复。
HashSet 和TreeSet 是两个主要的实现类。
List 有序且允许元素重复。
ArrayList 、LinkedList 和Vector 是三个主要的实现类。
Map 也属于集合系统,但和Collection 接口不同。
Map 是key 对value 的映射集合,其中key 列就是一个集合。
key 不能重复,但是val ue 可以重复。
HashMap 、TreeMap 和Hashtable 是三个主要的实现类。
SortedSet 和SortedMap 接口对元素按指定规则排序,SortedMap 是对key 列进行排序。
3.Q :Comparable 和Comparator 区别A:调用java.util.Collections.sort(List list)方法来进行排序的时候,List 内的Object 都必须实现了Comparable 接口。
java.util.Collections.sort(List list ,Comparator c),可以临时声明一个Comparator 来实现排序。
Collections.sort(imageList, new Comparator() { public int compare(Object a, Object b) {int orderA = Integer.parseInt( ( (Image) a).getSequence()); int orderB = Integer.parseInt( ( (Image) b).getSequence()); return orderA -orderB; } });如果需要改变排列顺序改成return orderb -orderA 即可。
4.Q:简述equals()和hashCode() A:...不知道。
下回分解public interface Collectionextends Iterablepublic interface Listextends Collectionpublic abstract class AbstractListextends AbstractCollection implements List有序否允许元素重复否Collection 否是List 是是Set AbstractSet 否否HashSet TreeSet是(用二叉树排序)MapAbstractMap 否使用key-value 来映射和存储数据,Key 必须惟一,value 可以重复HashMap TreeMap是(用二叉树排序)的错误--test4. re: Oracle 分页SQL我觉得你现在的第一条语句没什么错误啊--aegean5. re: 一个失败了的需求--button 模拟file 提交数据grdgvf--htf1. java.util.ConcurrentModificati onException(24671)2. JAVA 集合小结(11132)3. Oracle 分页SQL(6761)4. struts validate 之ValidatorActi onForm(925)5. WebSphere 下LinkageError 解决办法(825)1. Oracle 分页SQL(7)2. String StringBuffer(2)3. 一个失败了的需求--button 模拟file 提交数据(1)4. JAVA 集合小结(1)5. ThreadLocal 学习(1)阅读排行榜评论排行榜public classVectorextends AbstractListimplements List,RandomAccess,ng.Cloneable,java.io.Serializable基于Array是“sychronized”的public classArrayListextends AbstractListimplements List,RandomAccess,Cloneable,java.io.Serializable基于ArrayArrayList是非同步的。
所以在性能上要比Vector优越一些public classLinkedListextends AbstractSequentialListimplements List,Queue,Cloneable,java.io.Serializable不基于Array基于Array的List(Vector,ArrayList)适合查询,而LinkedList(链表)适合添加,删除操作List基本上都是以Array为基础。
但是Set则是在HashMap的基础上来实现的,这个就是Set和List的根本区别public abstract class AbstractSetextends AbstractCollectionimplements Setpublic class HashSetextends AbstractSetimplements Set, Cloneable, java.io.SerializableHashSet的存储方式是把HashMap中的Key作为Set的对应存储项public class LinkedHashSetextends HashSetimplements Set, Cloneable, java.io.Serializablepublic class TreeSetextends AbstractSetimplements SortedSet, Cloneable, java.io.Serializable它是通过SortedMap来实现的public interface Map<K,V>public abstract class AbstractMap<K,V>implements Map<K,V>public class HashMap<K,V>extends AbstractMap<K,V>implements Map<K,V>, Cloneable, Serializablepublic class TreeMap<K,V>extends AbstractMap<K,V>implements SortedMap<K,V>, Cloneable, java.io.SerializableHashMap通过hashcode对其内容进行快速查找,而TreeMap中所有的元素都保持着某种固定的顺序,如果你需要得到一个有序的结果你就应该使用TreeMap(HashMap中元素的排列顺序是不固定的)更详细的可以看:/view/article_695.html/happyzhm5/archive/2007/03/17/1532101.aspx/Java_apprentice/archive/2007/07/20/1700351.aspx解析Java对象的equals()和hashCode()的使用: /index.php?id=82&load=readposted on 2007-11-12 10:06 EvanLiu阅读(11133) 评论(1)编辑收藏 所属分类: Java基础FeedBack:#re: JAVA集合小结2008-03-23 20:49 矿矿不 大 懂我是新手!!回复更多评论新用户注册刷新评论列表找优秀程序员,就在博客园IT新闻:· Flip 之死· 只需10美元,Quirky就能将你的产品创意变成真实的产品· 亚马逊两周内升级Kindle Fire解决用户反映问题· 传腾讯将推出“Free talk” VoIP加速流量经营· eWeek:惠普保留webOS实为掩盖失败博客园博问IT新闻Java程序员招聘标题re: JAVA集合小结姓名主页验证码*内容(请不要发表任何与政治相关的内容)Remember Me?提交登录[使用Ctrl+Enter键可以直接提交]推荐职位:Copyright ©2011 EvanLiu Powered by: 博客园 模板提供:沪江博客· .NET 高级软件开发工程师(美国新蛋网)· 知识库技术编辑(博客园)· 北京C#开发工程师C/S 方向(圣特尔科技)· 北京 SQL 数据库开发工程师(圣特尔科技)· 北京.NET 研发工程师(北京捷报数据)· 上海.NET 工程师(中国房产信息集团有限公司)博客园首页随笔:· 让普通业余软件开发兴趣爱好者也快速开发出相对专业的软件产品 -通过实战开发讲解实现步骤· 去掉viewstate 生成的代码· LINQ 之路20:LINQ to XML 之Documents 、Declarations 和Namespaces · 使ViewFlipper 中的WebView 实现手势效果· [原创]HTML5.ManifestController -HTML5 Manifest 文件控制器知识库:· HTTP Caching 优化网站· 走向DBA[MSSQL 篇] -从SQL 语句的角度提高数据库的访问性能· Twitter 首席工程师:如何“打败”CAP 定理· HTML5标签使用的常见误区· T-SQL 查询进阶--深入浅出视图网站导航: 博客园IT 新闻知识库C++博客程序员招聘管理相关文章:WebSphere 下LinkageError 解决办法ThreadLocal 学习java.util.ConcurrentModificationException JMS 简单不完全实现JMS 基本概念(转)JAAS 学习String StringBuffer Oracle 分页SQL。