Nodejs连接数据库
1 nodejs连接数据库
1、下载mongodb模块 cnpm install mongodb
2、引入mongodb模块 const mongodb = require(“mongodb”);
3、链接数据库
const MongoClient = require('mongodb').MongoClient;
var dburl = "mongodb://127.0.0.1:27017/test";
MongoClient.connect(dburl,(err,db)=>{
if(err){
console.log('数据库连接失败!');
return;
};
console.log(db);
});
我们先定义一个dburl
变量用于指定本机上27017
端口号(mongodb
的默认端口号)上的数据库地址。test
为自定义的数据库的名字。若该数据库不存在则会自动完成该数据库的新建。接下去完成与本机上test
数据库的连接,这是一个异步函数,当连接完成之后,触发执行其回调函数,参数db
指代这个数据库本身。接下去对数据库的增删改查操作都写在连接的回调函数当中。
2 操作数据库
a插入数据
数据插入操作,指的是对数据库的某个指定集合进行文档对象的插入。同样是在完成数据库连接的回调函数当中对db
这个对象进行操作。示例代码如下所示:
const MongoClient = require('mongodb').MongoClient;
var dburl = "mongodb://127.0.0.1:27017/test";
MongoClient.connect(dburl,(err,db)=>{
if(err){
console.log('数据库连接失败!');
return;
};
db.collection('student').insertOne({"name":"qianqian"},(err,result)=>{
if(err){
console.log('数据插入失败!');
db.close();
return;
};
console.log(result);
db.close();
});
});
在用node
命令运行该文件之后,这时候我们可以在控制台或在可视化工具当中查看插入结果。
在db
对象的collection
方法当中写入集合的名字,若该集合不存在则自动完成新建,使用方法insertOne()
来完成一条文档的插入,第一个参数为一个json
对象,即插入的那一条文档数据。当完成插入操作之后触发执行其回调函数,result
表示对插入结果的反馈。由于数据库不能进行长连接,我们一般都在完成数据库操作的回调函数的最后加上db.close();
来关闭数据库。下一次数据库操作时需要重新连接数据库。
b)删除数据
数据删除操作,指的是对数据库的某个指定集合当中匹配上筛选条件的文档进行删除。同样是在完成数据库连接的回调函数当中对db
这个对象进行操作。示例代码如下所示:
const MongoClient = require('mongodb').MongoClient;
var dburl = "mongodb://127.0.0.1:27017/test";
MongoClient.connect(dburl,(err,db)=>{
if(err){
console.log('数据库连接失败!');
return;
};
db.collection('student').deleteMany({"name":"qianqian"},(err,result)=>{
if(err){
console.log('数据删除失败!');
db.close();
return;
};
console.log(result);
db.close();
});
});
使用方法deleteMany()
来对该集合当中所有符合筛选条件的文档全部进行删除,第一个参数为一个json
对象,即筛选条件。当完成删除操作之后触发执行其回调函数,result
表示对删除结果的反馈。
c)修改数据
数据修改操作,指的是对数据库的某个指定集合当中匹配上筛选条件的所有文档进行修改。同样是在完成数据库连接的回调函数当中对db
这个对象进行操作。示例代码如下所示:
const MongoClient = require('mongodb').MongoClient;
var dburl = "mongodb://127.0.0.1:27017/test";
MongoClient.connect(dburl,(err,db)=>{
if(err){
console.log('数据库连接失败!');
return;
};
db.collection('student').updateMany({"name":"qianqian"},{$set:{"age":18}},(err,result)=>{
if(err){
console.log('数据修改失败!');
db.close();
return;
};
console.log(result);
db.close();
});
});
使用方法updateMany()
来对该集合当中所有符合筛选条件的文档全部进行修改,第一个参数为一个json
对象,即筛选条件。第二个参数为一个json
对象,即修改条件,语法如上所示。当没有写$set
这个关键字,即{"age":18}
代表把匹配上的文档进行替换。当完成修改操作之后触发执行其回调函数,result
表示对修改结果的反馈。
d)查找数据
数据查找操作,指的是对数据库的某个指定集合当中匹配上筛选条件的所有文档进行查找。同样是在完成数据库连接的回调函数当中对db
这个对象进行操作。示例代码如下所示:
const MongoClient = require('mongodb').MongoClient;
var dburl = "mongodb://127.0.0.1:27017/test";
MongoClient.connect(dburl,(err,db)=>{
if(err){
console.log('数据库连接失败!');
return;
};
var cursor = db.collection("student").find({"name":"qianqian"});
var result = [];
cursor.each((err,doc)=>{
if(err){
console.log('数据查找失败!');
db.close();
return;
};
if(doc!=null){
result.push(doc);
}else{
console.log(result);
db.close();
};
});
});
使用方法find()
来对该集合当中所有符合筛选条件的文档全部进行查找,第一个参数为一个json
对象,即筛选条件。先定义一个空数组,用于存放符合条件的文档对象,当完成查找操作之后触发执行其回调函数,这里的result
表示符合条件的文档对象的数组。
我们在find()
方法后面继续加上sort()
方法可以实现对查找的文档对象的排序操作,参数同样是一个json
对象。此外mongodb
模块还提供了两个函数limit()
表示限制读取的条数,skip()
表示略过的条数。其参数均为number
类型。如把上述代码修改为: var cursor = db.collection("student").find({"name":"qianqian"}).sort({"age":-1}).skip(0).limit(2);
查找结果为:
e)获取该集合当中文档对象的总数
同样是在完成数据库连接的回调函数当中对db
这个对象进行操作。示例代码如下所示:
const MongoClient = require('mongodb').MongoClient;
var dburl = "mongodb://127.0.0.1:27017/test";
MongoClient.connect(dburl,(err,db)=>{
if(err){
console.log('数据库连接失败!');
return;
};
db.collection("student").count({}).then(function(count){
console.log(count);
db.close();
});
});
在回调函数当中的count
即代表数据库的student
这个集合当中数据文档的数目。