1. 程式人生 > >mongodb java增刪該查和模糊、排序和分頁查詢

mongodb java增刪該查和模糊、排序和分頁查詢

package mongodb;


import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import java.util.regex.Pattern;


import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.mongodb.Mongo;
import com.mongodb.MongoException;
import com.mongodb.QueryOperators;
import com.mongodb.ServerAddress;
import com.mongodb.WriteResult;


public class test {


public static void main(String[] args) throws Exception, MongoException {
System.out.println("start>>>>>>>>>>>>");
//使用哪個方法開啟哪個
//add();
//del();
//update();
//test3();
test4();
//delAll();
//queryPage();
//test5();
//test6();
//test7();
System.out.println("end>>>>>>>>>>>>>>");
}
//查詢個數。
public static void test7() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBCursor cursor = test1.find();
System.out.println("總個數count"+cursor.count());
System.out.println("總個數size"+cursor.size());
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
//in ,not in查詢
public static void test6()  throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject obj = new BasicDBObject();
//QueryOperators.IN 屬於   ,QueryOperators.NIN 不屬於
obj.put("sort",new BasicDBObject(QueryOperators.IN, new int[]{5,6,7}));
DBCursor cursor = test1.find(obj);
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
//大於,小於查詢
public static void test5()  throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject obj = new BasicDBObject();
//lte:小於等於, gte:大於等於 ,ne:不等於
obj.put("sort", new BasicDBObject("$lte",5));
DBCursor cursor = test1.find(obj);
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
//分頁
public static void queryPage() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
//limit 頁數  skip 開始
DBCursor cursor = test1.find().limit(10).skip(0).sort(new BasicDBObject("sort",1));
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
//刪除集合所有元素
public static void delAll() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
test1.remove(new BasicDBObject());
DBCursor cursor = test1.find();
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
//倒序查詢
public static void test4() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject dbo = new BasicDBObject();
dbo.put("sort", -1);
DBCursor cursor = test1.find().sort(dbo);
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
//模糊查詢
public static void test3() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject dbo = new BasicDBObject();
Pattern pattern = Pattern.compile("^.*angchunyu.*$",Pattern.CASE_INSENSITIVE);
dbo.put("username", pattern);
dbo.put("password", "123456");
DBCursor cursor = test1.find(dbo);
//多少個
System.out.println(cursor.size());
while (cursor.hasNext()) {
DBObject obj = cursor.next();
System.out.println(obj);
}
}
//新增資訊
public static void add() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject jo = new BasicDBObject();
jo.put("username", "xuxu");
jo.put("password", "123456");
jo.put("unitname", "中天國華");
jo.put("enabled", true);
jo.put("sort",8);
jo.put("sex", "女");
test1.save(jo);
DBCursor cursor = test1.find();
while (cursor.hasNext()) {
DBObject obj = cursor.next();
System.out.println(obj);
}
}
//刪除
public static void del() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject o = new BasicDBObject();
o.put("username", "zhangfei");
WriteResult num = test1.remove(o);
System.out.println(num);
DBCursor cursor = test1.find();
while (cursor.hasNext()) {
DBObject obj = cursor.next();
System.out.println(obj);
}
}
//修改
public static void update() throws Exception, MongoException{
Mongo mg = new Mongo();
DB db = mg.getDB("test");
DBCollection test1 = db.getCollection("test1");
DBObject oldobj = new BasicDBObject();
oldobj.put("username", "zhangfei");
DBObject newobj = test1.findOne(oldobj);
newobj.put("username", "zhangfeinew");
WriteResult num = test1.update(oldobj,newobj);
System.out.println(num.toString());
DBCursor cursor = test1.find();
while (cursor.hasNext()) {
DBObject obj = cursor.next();
System.out.println(obj);
}
}
//測試
public static void test1() throws Exception, MongoException{
//連線本地mongodb 預設為 127.0.0.1 埠為27017
Mongo mg = new Mongo();
/*DB db = mg.getDB("test");
DBCollection users = db.getCollection("users");
DBCursor cur = users.find();
System.out.println(users.count());
while(cur.hasNext()){
System.out.println(cur.next());
}*/
//版本號
String version = mg.getVersion();
System.out.println(version);
//資料庫名稱
List<String> dbnames = mg.getDatabaseNames();
System.out.println(dbnames);
//訪問地址
ServerAddress address = mg.getAddress();
System.out.println(address);
//連線test資料庫
DB db = mg.getDB("test");
//集合名稱
Set<String> collectionnames = db.getCollectionNames();
System.out.println(collectionnames);
//連線集合
DBCollection mycol = db.getCollection("mycol");

DBObject object1 = new BasicDBObject();
object1.put("name", "chunyu1");
object1.put("title", "title");
List list = new ArrayList();
list.add(1);
list.add(2);
list.add(3);
object1.put("list",list );
mycol.insert(object1);

DBObject object2 = new BasicDBObject();
object1.put("name", "chunyu");
object2.put("title", "title");
object2.put("list",list );

mycol.save(object1);
DBObject obj = new BasicDBObject();
obj.put("name", "chunyu");
DBCursor cursor = mycol.find();
//DBCursor cursor = mycol.find();
while(cursor.hasNext()){
System.out.println("11111>>>"+cursor.next());
/*DBObject ddd = cursor.next();
Set<String> sets = ddd.keySet();
for (String name : sets) {
Object value = ddd.get(name);
System.out.println(">>>"+value);
}*/
}
DBObject aaa = mycol.findOne();
System.out.println(aaa);

//mycol.drop();
}

}