java mongo使用

开启mongo服务

/usr/local/opt/mongodb/bin/mogod

链接mongo

mongo

查看所有的库

show dbs    

选择库

use 库名

查看所有的表

 db.getCollectionNames();

查看表的所有数据

db.表明.find()     

创建MongoDB 创建数据库的语法格式如下

use DATABASE_NAME
如果你想查看所有数据库,可以使用 show dbs 命令创建的库并不存在要向表里面插入一条数据
db.lihao.insert({"name":"李浩"})  

删除库

db.dropDatabase()

插入文档

MongoDB 使用 insert() 或 save() 方法向集合中插入文档

db.COLLECTION_NAME.insert(document)

db.lihao.insert({"title": 'MongoDB 教程',
     "description": 'MongoDB 是一个 Nosql 数据库',
     "by": '菜鸟教程',
     "url": 'http://www.runoob.com',
     "tags": ['mongodb', 'database', 'NoSQL'],
     "likes": 100
 })

更新文档

update() 方法

db.collection.update(
   <query>,
   <update>,
   {
     upsert: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)

参数说明:

  • query : update的查询条件,类似sql update查询内where后面的。
  • update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
  • upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
  • multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
  • writeConcern :可选,抛出异常的级别。
实例
db.lihao.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}})

save() 方法

db.collection.save(
   <document>,
   {
     writeConcern: <document>
   }
)
实例
db.lihao.save({"title":"李三"})

更多实例

只更新第一条记录:
db.col.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } );
全部更新:
db.col.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true );
只添加第一条:
db.col.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false );
全部添加加进去:
db.col.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true );
全部更新:
db.col.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );
只更新第一条记录:
db.col.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );

remove() 删除文档

db.collection.remove(
   <query>,
   {
     justOne: <boolean>,
     writeConcern: <document>
   }
)

db.lihao.remove({"title":"李三"}) 

删除所有数据

db.col.remove({})

MongoDB 查询文档

语法格式

db.COLLECTION_NAME.find()
db.lihao.find({"title":"MongoDB"})

条件

操作 格式 范例 rdbms中类似语句
等于 {<key>:<`value>} db.col.find({"by":"菜鸟教程"}) where by = '菜鸟教程
小于 {<key>:{$lt:<value>}} db.col.find({"likes":{$lt:50}}) where likes < 50
小于或等于 {<key>:{$lte:<value>}} db.col.find({"likes":{$lte:50}}) where likes <= 50
大于 {<key>:{$gt:<value>}} db.col.find({"likes":{$gt:50}}) where likes > 50
大于或等于 {<key>:{$gte:<value>}} db.col.find({"likes":{$gte:50}}) where likes >= 50
不等于 {<key>:{$ne:<value>}} db.col.find({"likes":{$ne:50}}) where likes != 50
模糊 {<key>:{$regex:<value>}} db.lihao.find({"title":{$regex: 'Mon', $options:'i'}}) where title like "%Mon%"

MongoDB Limit与Skip方法

MongoDB Limit() 方法

如果你需要在MongoDB中读取指定数量的数据记录,可以使用MongoDB的Limit方法,limit()方法接受一个数字参数,该参数指定从MongoDB中读取的记录条数.

语法

db.COLLECTION_NAME.find().limit(NUMBER)
db.test.find().limit(2)

MongoDB skip() 方法

我们除了可以使用limit()方法来读取指定数量的数据外,还可以使用skip()方法来跳过指定数量的数据,skip方法同样接受一个数字参数作为跳过的记录条数。

语法

db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)    
db.test.find().limit(2).skip(2)

MongoDB 排序

MongoDB sort()方法

在MongoDB中使用使用sort()方法对数据进行排序,
sort()方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而-1是用于降序排列。

语法

db.COLLECTION_NAME.find().sort({KEY:1}) 

java 操作mongodb

添加 mongo-java-driver-3.3.0.jar

连接mongo

String uriStr = "mongodb://127.0.0.1:27017/";
MongoClientURI uri = new MongoClientURI(uriStr);
MongoClient mongoClient = new MongoClient(uri);

创建数据库

public void createDatabase(){
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);
    // 连接到数据库 如果不存在会创建数据库
    MongoDatabase mongoDatabase = mongoClient.getDatabase("mycol");
    //不创建表数据库创建不成功
    mongoDatabase.createCollection("test");
}

查看所有的数据库

public void showDbs() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoclient = new MongoClient(uri);

    //查看所有的库
    List<String> database = mongoclient.getDatabaseNames();
    System.out.println(database.size());
    System.out.println(database);

    //打开指定库
    MongoDatabase db = mongoclient.getDatabase("testdb");
    System.out.println(db.getName());

    mongoclient.close();

}

查看库里面的表

public void showTables() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);

    MongoDatabase testDb = mongoClient.getDatabase("testdb");
    MongoIterable<String> tables = testDb.listCollectionNames();
    System.out.println(tables);
    MongoCursor<String> it = tables.iterator();
    while (it.hasNext()) {
        System.out.println(it.next());
    }
}

insert 插入数据插入一条

public void insert() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);
    MongoDatabase database = mongoClient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");

    MongoBean bean =  new MongoBean("huangdiandian",25,2);
    Gson gson = new Gson();
    Document document = Document.parse(gson.toJson(bean));
    account.insertOne(document);
}

insertMany 插入多个数据

public void inserMany() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);
    MongoDatabase database = mongoClient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");
    ArrayList<Document> listMongo = new ArrayList<Document>();
    Gson gson = new Gson();

    for(int i=1;i<10;i++) {
        MongoBean bean =  new MongoBean("huangdiandian"+i,25+i,2);
        listMongo.add( Document.parse(gson.toJson(bean)));
    }
    account.insertMany(listMongo);

}

update 更新数据

public void update() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);
    MongoDatabase database = mongoClient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");
    
    //提交 相当于 where
    BasicDBObject where = new BasicDBObject();
    where.append("name","li");

    //设置 值  set
    Document set = new Document();
    set.append("name","乐约");
    set.append("age",23);
    //修改多个可以用updateMany
    account.updateOne(where,new Document("$set",set));
    mongoClient.close();
}

delete 删除数据

public void delete() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoclient = new MongoClient(uri);
    MongoDatabase database = mongoclient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");
    
    //where 条件
    Document document =  new Document();
    document.append("name","乐约");
    document.append("age",4);
    //删除多个用deleteMany()
    DeleteResult del = account.deleteOne(document);
    System.out.println("删除了: "+del.getDeletedCount());
    
    mongoclient.close();

}    

find 查询显示指定字段

public void findWidthField() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);
    MongoDatabase database = mongoClient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");
    
    //显示指定字段
    Document fieldBeson = new Document();
    fieldBeson.put("name", true);
    fieldBeson.put("age", true);
    fieldBeson.put("_id", false);

    FindIterable<Document> documents = account.find().projection(fieldBeson);
    for (Document document : documents) {
        System.out.println(document);
    }

    mongoClient.close();

}

find 按照条件查询

 public void findWidthCondition() {
    QueryOperators.
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoClient = new MongoClient(uri);
    MongoDatabase database = mongoClient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");
    // age 大于等于 22
    BasicDBObject queryBeson = new BasicDBObject();
    // age >= 22
    queryBeson.append("age",new BasicDBObject(QueryOperators.GTE,22));
    queryBeson.append(QueryOperators.GTE,new BasicDBObject("age",22));
    // age = 22  or age = 20
    queryBeson.append(QueryOperators.OR,new BasicDBObject[] { new       BasicDBObject("age", 22),
            new BasicDBObject("age", 20) } );

    //name=lihao and age=1
    queryBeson.append(QueryOperators.AND,new BasicDBObject[]{
            new BasicDBObject("name","lisan"),
            new BasicDBObject("sex",1)

    });
    //name = li
    queryBeson.append("name",new BasicDBObject(QueryOperators.IN,new String[]{"li"}));


    findCondition(account, queryBeson);


    mongoClient.close();

}

private void findCondition(MongoCollection<Document> account, BasicDBObject queryBeson) {
    Document fieldBeson = new Document();
    fieldBeson.put("name", true);
    fieldBeson.put("age", true);
    fieldBeson.put("sex", true);
    fieldBeson.put("_id", false);

    FindIterable<Document> documents = account.find(queryBeson).projection(fieldBeson);

    for (Document document : documents) {
        System.out.println(document);
    }
}

limit 显示指定行数的数据

public void limit() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoclient = new MongoClient(uri);
    MongoDatabase database = mongoclient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");

    FindIterable<Document> documents = account.find().limit(2);
    for(Document document : documents) {
        System.out.println(document.toJson());
    }
}

skip 来跳过指定数量的数据

 public void skip() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoclient = new MongoClient(uri);
    MongoDatabase database = mongoclient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");

    FindIterable<Document> documents = account.find().limit(2).skip(2);
    for(Document document : documents) {
        System.out.println(document.toJson());
    }
}    

sort 排序

public void sort() {
    String uriStr = "mongodb://127.0.0.1:27017/";
    MongoClientURI uri = new MongoClientURI(uriStr);
    MongoClient mongoclient = new MongoClient(uri);
    MongoDatabase database = mongoclient.getDatabase("testdb");
    MongoCollection<Document> account = database.getCollection("account");

    //order by 1 正序 -1 倒叙
    Document document = new Document().append("age",-1);

    FindIterable<Document> documents = account.find().sort(document);
    for(Document doc : documents) {
        System.out.println(doc.toJson());
    }

}

2016.12.15

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容