MongoDB 4.2.7安装后,除了‘show dbs’你还能用命令行做这些事(新手快速上手)
MongoDB 4.2.7安装后命令行实战:从零开始玩转数据库
当你看到show dbs成功显示数据库列表时,说明MongoDB已经准备就绪。但接下来呢?命令行界面就像一片未知海域,而我们将带你从浅滩开始探索。以下是几个能让新手快速获得成就感的实战操作:
1. 创建你的第一个数据库和集合
在MongoDB中,数据库和集合的创建是隐式的——当你第一次插入数据时它们就自动存在了。试试这个简单的操作序列:
// 切换到新数据库(如果不存在会自动创建) use myFirstDatabase // 插入第一条文档(集合也会自动创建) db.myCollection.insertOne({ name: "初学者指南", difficulty: "easy", tags: ["mongodb", "tutorial", "beginner"], created_at: new Date() })执行后你会看到类似这样的响应:
{ "acknowledged" : true, "insertedId" : ObjectId("5f8d...") }注意:MongoDB中的日期类型建议使用
new Date()而不是字符串,这样可以利用日期查询功能
2. 批量插入与基础查询
现在让我们用更真实的数据来练习:
// 批量插入多条文档 db.users.insertMany([ { username: "dev_amy", email: "amy@example.com", role: "admin", last_login: new Date("2023-05-15") }, { username: "coder_bob", email: "bob@dev.io", role: "user", last_login: new Date("2023-06-20") }, { username: "test_user", email: "test@test.org", role: "guest", last_login: new Date("2023-06-01") } ]) // 查询所有用户 db.users.find() // 带条件的查询 db.users.find({ role: "admin" }) // 使用比较操作符 db.users.find({ last_login: { $gt: new Date("2023-06-10") } })常用查询操作符速查表:
| 操作符 | 说明 | 示例 |
|---|---|---|
$eq | 等于 | {age: {$eq: 25}} |
$gt | 大于 | {score: {$gt: 90}} |
$in | 在数组中 | {role: {$in: ["admin","user"]}} |
$regex | 正则表达式匹配 | {email: {$regex: /example/}} |
3. 更新文档的多种姿势
MongoDB提供了灵活的更新方式:
// 更新单个文档 db.users.updateOne( { username: "test_user" }, { $set: { role: "user", updated_at: new Date() } } ) // 更新多个文档 db.users.updateMany( { role: "user" }, { $inc: { login_count: 1 } } ) // 替换整个文档 db.users.replaceOne( { username: "dev_amy" }, { username: "dev_amy", email: "amy.new@example.com", roles: ["admin", "supervisor"], metadata: { department: "IT" } } )更新操作符实用技巧:
$set:设置字段值(不存在则创建)$unset:删除字段$inc:数值增减$push:向数组添加元素$addToSet:向数组添加不重复元素
4. 删除操作与数据库管理
当需要清理数据时:
// 删除单个文档 db.users.deleteOne({ username: "test_user" }) // 删除所有匹配文档 db.users.deleteMany({ role: "guest" }) // 删除整个集合 db.myCollection.drop() // 删除当前数据库 db.dropDatabase()重要提示:生产环境慎用
drop命令!建议先执行find确认要删除的数据
5. 进阶查询技巧
掌握这些查询方法能让你的操作更高效:
// 字段投影(只返回指定字段) db.users.find({}, { username: 1, email: 1, _id: 0 }) // 排序结果 db.users.find().sort({ last_login: -1 }) // -1表示降序 // 分页查询 db.users.find().skip(10).limit(5) // 复杂条件组合 db.users.find({ $or: [ { role: "admin" }, { last_login: { $gt: new Date("2023-06-01") }, login_count: { $gte: 5 } } ] }) // 聚合统计 db.users.aggregate([ { $group: { _id: "$role", count: { $sum: 1 }, lastActivity: { $max: "$last_login" } }} ])6. 索引优化初探
随着数据量增长,索引会成为性能关键:
// 创建单字段索引 db.users.createIndex({ username: 1 }) // 1表示升序 // 创建复合索引 db.users.createIndex({ role: 1, last_login: -1 }) // 查看集合索引 db.users.getIndexes() // 删除索引 db.users.dropIndex("username_1")索引使用建议:
- 为常用查询字段创建索引
- 复合索引字段顺序很重要
- 索引会占用存储空间并影响写入性能
- 使用
explain()分析查询执行计划
7. 日常维护命令备忘
这些命令能帮助你了解数据库状态:
// 查看所有数据库 show dbs // 查看当前数据库集合 show collections // 查看集合统计信息 db.users.stats() // 查看命令执行统计 db.serverStatus() // 查看当前连接 db.currentOp() // 安全关闭MongoDB(在admin数据库执行) use admin db.shutdownServer()记住,MongoDB的命令行操作就像搭积木——简单命令组合起来就能完成复杂任务。当你熟悉这些基础操作后,可以尝试更高级的特性如事务、聚合管道和MapReduce。
