mongo db 学习笔记 之一: mongodb 初认识
admin
2023-04-12 16:21:29
0


官网文章,对比SQL和mongodb

http://docs.mongodb.org/manual/reference/sql-comparison/


  1. db --显示当前使用的库

  2. show dbs --显示所有库

  3. use db

  4. show collections --显示当前数据库的所有表

  5. db.testData.find() --选择要操作的数据库之后,db代表当前数据库对象,testData代表数据表,在mongo里table叫作collection. find()函数返回所有记录(record),在mongo里一条记录叫做document.如果返回的数据记录非常大超过20条,默认只会返回首20条,要按“it”(iterate)来继续显示下面20条记录。

  6. db.testData.insert() -- 插入数据

  7. db.data.find({"_id" : "3"}) --查找指定记录

  8. db.testData.findOne()

  9. db.testData.find().limit(3)



mongo的shell操作交互窗口的语言风格是javascript语法,比如:


j = { name : "mongo" }k = { x : 3 }

db.testData.insert( j )db.testData.insert( k )

表示插入了两条记录。

{ "_id" : ObjectId("4c2209f9f3924d31102bd84a"), "name" : "mongo" }
{ "_id" : ObjectId("4c2209fef3924d31102bd84b"), "x" : 3 }

_id是一个表里的唯一值,如果不指定,默认系统会分配一个记录一个唯一的_id,也可以指定_id:

> testdate={"_id":"3", "isp_id":"1000314","ip":"58.177.249.38","request_url":"\/bruce\/laiye\/","referer":null,"_ref":null,"user_agent":"Mozilla\/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko\/20100101 Firefox\/31.0"}
{
    "_id" : "3",
    "isp_id" : "1000314",
    "ip" : "58.177.249.38",
    "request_url" : "/bruce/laiye/",
    "referer" : null,
    "_ref" : null,
    "user_agent" : "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko/20100101 Firefox/31.0"
}
> db.data.insert(testdate)
WriteResult({ "nInserted" : 1 })


> db.data.find({"_id" : "3"})
{ "_id" : "3", "isp_id" : "1000314", "ip" : "58.177.249.38", "request_url" : "/bruce/laiye/", "referer" : null, "_ref" : null, "user_agent" : "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.9; rv:31.0) Gecko/20100101 Firefox/31.0" }

javascript语法

//利用循环快速插入25条记录
for (var i = 1; i <= 25; i++) db.testData.insert( { x : i } )

//输出所有记录
var c = db.testData.find()
while ( c.hasNext() ) printjson( c.next() )


//查找特定结果
var c = db.testData.find()
printjson( c [ 4 ] )
//结果
{ "_id" : ObjectId("51a7dc7b2cacf40b79990bea"), "x" : 5 }

//还能在操作窗口里写function,然后直接调用!!牛B!!
//先定义insertData函数
function insertData(dbName, colName, num) {

  var col = db.getSiblingDB(dbName).getCollection(colName);

  for (i = 0; i < num; i++) {
    col.insert({x:i});
  }

  print(col.count());}
  
  //调用
  insertData("test", "testData", 400)


相关内容

热门资讯

民进党明天拟正式提名沈伯洋参选... 针对外传民进党将于13日正式拍板征召不分区民代沈伯洋参选台北市长,对决中国国民党现任市长蒋万安一事,...
内塔尼亚胡称中国支持伊朗制造导... ‍‍5月12日,外交部发言人郭嘉昆主持例行记者会。有外媒记者提问,以色列总理内塔尼亚胡在接受采访时表...
AI会取代哪些职业?多个AI意... 当前,人们日益担忧人工智能(AI)将影响就业市场。美国近期一项研究显示,多个人工智能模型在预测哪些职...
大疆Air 4无人机曝光,预估... IT之家 5 月 12 日消息,消息源 Igor Bogdanov 昨日(5 月 11 日)在 X ...
中核国电漳州能源原党委书记、董... 中核集团中核国电漳州能源有限公司原党委书记、董事长何辉涉嫌严重违纪违法,目前正接受中央纪委国家监委驻...
总投资1.85亿元,郑州市金水... 【大河财立方消息】 5月11日,金水区人民政府对金水区城市更新项目入库信息进行公示,公示期为2026...
特朗普访华期间是否会讨论台湾和... 澎湃新闻记者 聂舒翼 谢瑞强5月12日,外交部发言人郭嘉昆主持例行记者会。有记者就特朗普访华期间是否...
AI+教育,郑州航空港区成果亮... 【大河财立方 记者 程帅星】5月11日,由教育部、浙江省人民政府共同主办的2026世界数字教育大会在...
外交部:中方反对美国向中国台湾... 新华社北京5月12日电(记者万倩仪、冯歆然)外交部发言人郭嘉昆12日在例行记者会上就中美关系和台湾问...
外交部:亚太各国应擦亮眼睛,共... 新华社北京5月12日电(记者董雪、孙楠)外交部发言人郭嘉昆5月12日在例行记者会上回答相关问题时表示...