首页数据库mongodb创建数据库?mongodb数据库如何建表

mongodb创建数据库?mongodb数据库如何建表

编程之家2023-10-22200次浏览

大家好,关于mongodb创建数据库很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于mongodb数据库如何建表的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!

mongodb创建数据库?mongodb数据库如何建表

如何在MongoDB中建立新数据库和集合

由于Mongodb不是关系型数据库文件,实际上,它并不存在传统关系型数据库中的所谓ldquo;数据库rdquo;的概念,但不用担心,当你第

创建Mongodb数据库

由于Mongodb不是关系型数据库文件,实际上,它并不存在传统关系型数据库中的所谓“数据库”的概念,但不用担心,当你第一次新增数据时,mongodb就会以collection集合的形式进行保存和新建,而不需要你手工去新建立。下面是例子:

1)列出当前的数据库

MongoDB shell version: 1.8.1

mongodb创建数据库?mongodb数据库如何建表

connecting to: test

> show dbs-

admin 0.03125GB

local(empty)

可以使用show dbs来列出当前有多少个数据库,上面看到的是有两个,分别是admin和local。

2)定义新的数据库名

mongodb创建数据库?mongodb数据库如何建表

我们通过使用“use new-databasename”的语法去使用一个新的数据库,注意,即使你的数据库还没建立起来,依然可以这样使用,因为mongodb会在真正插入了数据后,才会真正建立起来。

>use mkyongdb

switched to db mkyongdb

> show dbs

admin 0.03125GB

local(empty)

注意,在use mkyongdb后,mkyongdb实际上还没真正建立起来,只是表明目前是在使用mkyongdb了。

3)保存数据

定义一个collection,名为“users”,然后插入数据,如下:

> db.users.save({username:"mkyong"})

> db.users.find()

{"_id": ObjectId("4dbac7bfea37068bd0987573"),"username":"mkyong"}

> show dbs-

admin 0.03125GB

local(empty)

mkyongdb 0.03125GB

可以看到,用db.users.find()可以找出已插入的数据。这个时候,,名为“users”的collection已经建立起来了,同时,数据库mkyongdb也建立起来了。

mongodb如何快速搭建属于自己的数据库

本章给大家介绍mongodb如何快速搭建属于自己的数据库。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

mongoddb安装

在本地安装

直接通过官网下载机子对应的压缩包 mongodb

在云服务器(centos系统)安装

wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-amazon-3.4.9.tgztar zxvf mongodb-linux-x86_64-3.2.6.tgz

mv mongodb-linux-x86_64-3.2.6.tgz mongodb

cd mongodb

请根据你的的系统下载相应的版本~

环境配置&启动服务器

在文件目录下建立存放数据的文件夹一般目录就是/usr/local/mongodb/data/db/通过运行命令去启动mongodb

./bin/mongod--dbpath=/usr/local/mongodb/data/db/--rest这里有几个参数重点说明一下,mongod为你mongodb的命令行支持可以启动,如果有需要可以通过编辑/etc/profile编辑进全局环境,dbpath也就是数据路径,对应你建立的data目录即可。--rest则是一个图形支持

mongodb的默认路径为//localhost:27017运行成功后访问这个地址酒会有成功的提示加上rest参数可以访问//localhost:28017

./bin/mongo可以打开shell

常用命令:

#查询所有数据库 show dbs;

#删除当前使用数据库 db.dropDatabase();

#克隆主机数据 db.cloneDatabase(“127.0.0.1”);

#修复当前数据库 db.repairDatabase();

#查看当前使用的数据库 db.getName();

#显示当前db状态 db.stats();

#查看当前db的链接机器地址 db.version();云服务器上部署mongodb环境

现在云端非常流行,很多人选择了用云服务器来部署自己的项目,这里就介绍一下云端的mongodb配置。

./bin/mongod--fork--dbpath=/usr/local/mongodb/data/db/--logpath=/usr/local/mongodb/data/log/error.log-logappend--rest数据库部署到云服务器就需要后台运行,一开始用的centos的forever插件,发现并不能后台运行数据库。查阅了一下资料发现官方就有命令--fork启动后台服务--logpath--logappend参数为后台服务加个log日志 rest效果同上面。

让数据库更直观

密密麻麻的数据是不是很丑?很难受?这个时候我们就需要一个美化数据库的插件了

网上有很多如 mongovue, adminmongo可以搜索活着Github上查阅一下。

以下是数据库加密,我也是上线被攻击后才痛定思痛更新了加密过程。

添加超级管理员

首先,运行你的数据库,成功后执行shell操作。

> use admin

> db.createUser(

{

user:"your name",

pwd:"your pwd",

roles: [{ role:"root", db:"admin"} ]

}

)

Successfully added user:{

"user":"admin",

"roles": [

{

"role":"root",

"db":"admin"

}

]

}root表示超级权限,这样就创建了具有超级权限的账号了。可以通过以下命令来查看用户。

[Uploading image_088895.png...]

db.getUsers()MongoDB数据库角色

role指角色,管理控制数据库的权限,第一个用户最好是root用户,可以执行任何操作,

初始化最好创建root权限的用户,当开启auth模式,任何操作都需要权限才能执行。也千万不能直接auth启动后台运行模式,否则你就没有权限用户去关闭数据库。

Read:允许用户读取指定数据库

readWrite:允许用户读写指定数据库

dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile

userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户

clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。

readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限

readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限

userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限

dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。

root:只在admin数据库中可用。超级账号,超级权限

启动auth模式

在创建完超级管理员后,才能真正启动加密的数据库,否则即使你自己也无权去操作数据库。

//后台模式需要在shell中关闭之前的普通模式数据库,输入以下命令

> use admin

> db.shutdownServer()

//终端启动加密数据库--auth

$./bin/mongod--fork--dbpath=/root/mongodb/db/--logpath=/root/mongodb/log/error.log-logappend--auth

//通过命令运行数据库,在你的运行命令加上后缀--auth,这样就启动了加密数据库,再次执行数据库操作

> show dbs

2017-09-23T14:09:58.922+0800 E QUERY [thread1] Error: listDatabases failed:{

"ok": 0,

"errmsg":"not authorized on admin to execute command{ listDatabases: 1.0}",

"code": 13,

"codeName":"Unauthorized"

}:

_getErrorWithCode@src/mongo/shell/utils.js:25:13

Mongo.prototype.getDBs@src/mongo/shell/mongo.js:62:1

shellHelper.show@src/mongo/shell/utils.js:769:19

shellHelper@src/mongo/shell/utils.js:659:15

@(shellhelp2):1:1

//发现报错,需要认证信息

> db.auth('your name','your pwd')

成功返回1失败返回0输入之前创建的超级账号,OK,简单的加密就完成了。

加密成功,需要认证才能操作数据库

链接加密数据库

数据库加密后我们的服务端代码也要相应变动。

xxx.db('mongodb://your name: your pwd@localhost:27017/db?authSource=admin');xxx表示你用的插件比如 mongoose、mongoskin之类的。

到此为止,你的数据库就加密完成了,当你的项目变大,你也许还需要创建许多用户,或者升级用户权限,这些官方都有相关的API去操作。

mongodb数据库如何建表

MongoDB创建表步骤,Mongo常用的数据库操作命令,查询,添加,更新,删除_MongoDB性能监测。

use Admin(切换到创建用户)

db.TestDb(创建数据库)

db.addUser(“userName”,”Pwd”)创建用户

db.auth(“userName”,”Pwd”)设置用户为允许连接的用户

db.createCollection(“TableName”)创建表

showcollections查看表是否创建成功

db.TableName.Save({age:1})添加数据

db.TableName.find()查看添加的数据是否成功(如果没有查询到任何的结果,说明添加失败)

推荐学习《python教程》。

windows下安装好mongodb后怎么创建数据库

一、安装mongoDB

1、解压mongodb-win32-i386-1.8.2至E:\MyProgram\mongodb-win32-i386-1.8.2(你可以按照自己的路径来,路径中最好不要有空格,要不然麻烦)

2、新建文件夹C:\DATA\DB,这是mongoDB的默认数据文件夹,你也可以在文件夹E:\MyProgram\mongodb-win32-i386-1.8.2新建一个文件夹data作为mongoDB的数据库文件存储目录

3、进入CMD,运行命令E:\MyProgram\mongodb-win32-i386-1.8.2\bin\mongod.exe-dbpath E:\MyProgram\mongodb-win32-i386-1.8.2\data,OK,mongoDB已经安装成功并已经在运行中了,你将会看到如下:

此时是mongoDB的运行状态,你可以按Ctrl+C结束运行状态或者直接关掉CMD结束运行。

二、运行mongoDB时的错误与处理

完成安装后,结束掉所有CMD窗口,然后进行如下操作:

1、运行E:\MyProgram\mongodb-win32-i386-1.8.2\bin\mongo,可能会报错误:couldn't connect to server 127.0.0.1 shell/mongo.js,原因是mongod.exe没有启动,

2、既然没启动,那咱就启动呗,运行E:\MyProgram\mongodb-win32-i386-1.8.2\bin\mongod,可能会报错误:dbpath(/data/db/) does not exist, terminating,看这样子,本人觉得还得在data文件夹下再建一个db文件夹啊,如此即新建一db文件夹,再运行mongod命令,结果提示一样,不知道怎么搞啦,咱google吧

找到文章http://www.mongodb.org/display/DOCS/Starting+and+Stopping+Mongo

说“To start Mongo in default mode, where data will be stored in the/data/db directory(or c:\data\db on Windows), and listening on port 27017”,哦,原来默认的文档路径在c:\data\db,啥也不说,直接按这个建文件夹,再次运行命令mongod,OK了,启动成功,这个命令窗口不能关闭,否则mongoDB就退出了

三,使用mongo命令

保持mongod命令窗口的运行状态,再新开一命令窗口

输入E:\MyProgram\mongodb-win32-i386-1.8.2\bin\mongo,出现

MongoDB shell version:1.8.2

connecting to:test

>

OK,连接成功。

1,show dbs显示数据库列表

2,use Northwind进入Northwind数据库,大小写敏感

3,show collections显示数据库中的集合

4,db用于查看当前所在的数据库

5,db.Customer.count()查看集合Customer的记录总数

6,db.Customer.findOne({"_id":"1"})查看CustomerId=1的记录

新增数据

1,use MyTest,这个数据库不存在,无所谓,mongo会创建,

MongoDB在使用前,并不要求您事先创建好相应的数据库,设计数据表结构!

在MongoDB中,没有【表】的概念,取而代之的是【集合】,也没有【数据记录】的概念,取而代之的是【文档】,我们可以把【文档】理解成一个【对象】,任意的对象,甚至可以有复杂的嵌套层次。

因此,我们不用再写代码从【数据表字段】到C#类的【属性,字段】的转换了,现在直接就可以读写整个对象了。

而且MongoDB不支持Join操作,所以,如果有【关联】操作,就需要你自己来处理

2,item={"Key":"1","text":"wokao","number":3}

3,db.table1.insert(item),mongo将建立集合table1,并将item插入,完成了新增加数据库的工作

4,db.table1.find()显示table1中的数据,MongoDB的文档使用的是一种称为BSON格式的对象,与Javascript中的JSON类似

5,额外的,输入item1={"Id":5,"str":"asdfasdf"},再插入db.table1.insert(item1),再用find()命令看,也插入成功了~,注意到结构和item不一样!但不建议这样做。

注意到:【每个文档有一个名为"_id"的成员】,我可没有定义啊。

其实,MongoDB会为每个文档都创建这样一个文档成员,我们指定的"key","id"对于MongoDB来说:它们并不是【文档的主键】,MongoDB只认"_id",你可以指定,但如果不指定,MongoDB就自动添加。

修改数据

1,var t=db.table1.findOne({"Id":5}),获取一条记录

2,t.str="wokao"

3,db.table1.update({"Id":5},t)

删除数据

db.table1.remove({"Id":5})

查找数据

上面已经有find和findOne命令,即用于查询

db.table1.find()

MongoDB的查询条件中,并没有>,<,>=,<=这些运算符,而是使用"$lt","$lte","$gt","$gte"

新建表

db.MyTest.table2.save({})

删除表

db.table1.drop()或db.runCommand({"drop","table1"})

删除数据库

db.runCommand({"dropDatabase": 1}),此命令只能删除当前数据库

获取服务端状态信息

db.runCommand({"serverStatus": 1})

关于mongodb创建数据库到此分享完毕,希望能帮助到您。

阿里云服务器免费(有哪些免费的云服务器)阿里云服务器安全 阿里云服务器安全性怎么样有什么安全防护措施