#切换数据库
use mongodb;
#同时创建数据库mongodb,和表temp_test
db.createCollection('temp_test');
#创建唯一索引,哈希类型
db.getCollection("temp_test").createIndex({ user_phone: "hashed"},{unique: true,background: true, sparse: true });
#创建普通索引
db.getCollection("temp_test").createIndex({ create_time: 1},{background: true, sparse: true });
#获取索引信息
db.getCollection("temp_test").getIndexes();
#查看表信息
db.getCollection('temp_test').stats();
#创建分片库表
use admin;
#创建分片库
db.runCommand({enablesharding:"mongodb"});
#创建分片表
db.runCommand({shardcollection:"mongodb.orders",key:{'userid':'hashed'} });
#查看分片状态
sh.status();
#用户
db.createUser({user: "admin_test",pwd: "123456",roles: [ { role: "dbOwner", db: "test_db1" } ,{role:"dbOwner",db:"test_db2"}]});
db.createUser({user:"root",pwd:"123456",roles:["root"]});
db.dropUser("admin_test");
use admin;
db.system.users.find({},{userId:0,credentials:0}).pretty();
#单行插入
db.collection.insertOne({"name":"aaa"});
#多行插入
db.collection.insertMany([{"name":"aaa"},{"name":"bbb"}]);
#清空表
db.collection.deleteMany({})
#删除{ status : "A" }的全部文档
db.collection.deleteMany({ status : "A" })
#删除{ status : "A" }的一条文档
db.collection.deleteOne({ status : "A" })
#更新某一行数据的指定字段的值
db.collection.updateOne({"user_age":18},{$set:{"user_name":"aaa","sex":"男"}});
#更新指定字段的值
db.collection.updateMany({"user_age":18},{$set:{"user_name":"aaa"}});
#查询示例
db.getCollection('order').find(
{
"create_time":{
$gte:ISODate("2019-12-31 16:00:00"),
$lte:ISODate("2020-12-31 16:00:00")
},
"_class":{$exists:true},
"djlb":{$in:["W","T"]}
},{
"user_phone":1,
"create_time":1
}
);
db.getCollection('order').find(
{
_id:{
$gte:ObjectId("5e0be1000000000000000000"),
$lt:ObjectId("5fee66000000000000000000")
}
);