在使用Java从MongoDB集合中检索数据时,如何限制记录数?
从MongoDB集合中检索记录时,您可以使用以下方法限制结果中的记录数:
limit()方法。
语法
db.COLLECTION_NAME.find().limit(no.of records needed)
JavaMongoDB库提供了一个具有相同名称的方法,以find()
通过传递表示所需记录数的整数值来限制调用此方法的记录数(在该方法的结果上)。
示例
import com.mongodb.client.FindIterable; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import org.bson.Document; import com.mongodb.MongoClient; public class LimitingRecords { public static void main( String args[] ) { //创建一个MongoDB客户端 MongoClient mongo = new MongoClient( "localhost" , 27017 ); //连接到数据库 MongoDatabase database = mongo.getDatabase("myDatabase"); //创建一个收集对象 MongoCollection<Document>collection = database.getCollection("students"); Document document1 = new Document("name", "Ram").append("age", 26).append("city", "Hyderabad"); Document document2 = new Document("name", "Robert").append("age", 27).append("city", "Vishakhapatnam"); Document document3 = new Document("name", "Rhim").append("age", 30).append("city", "Delhi"); Document document4 = new Document("name", "Radha").append("age", 28).append("city", "Mumbai"); Document document5 = new Document("name", "Ramani").append("age", 45).append("city", "Pune"); //插入创建的文档 List<Document> list = new ArrayList<Document>(); list.add(document1); list.add(document2); list.add(document3); list.add(document4); list.add(document5); collection.insertMany(list); System.out.println("Documents Inserted"); //检索集合对象 collection = database.getCollection("students"); //检索文档有限制 FindIterable<Document> iterDoc = collection.find().limit(3); Iterator it = iterDoc.iterator(); while (it.hasNext()) { System.out.println(it.next()); } } }
输出结果
Documents Inserted Document{{_id=5e887b16dac53c7f07cfd740, name=Ram, age=26, city=Hyderabad}} Document{{_id=5e887b16dac53c7f07cfd741, name=Robert, age=27, city=Vishakhapatnam}} Document{{_id=5e887b16dac53c7f07cfd742, name=Rhim, age=30, city=Delhi}}