mongodb操作的模块手动封装
程序员文章站
2022-03-09 09:01:30
mongodb操作的模块手动封装
[注]:这些代码都是基于nodejs进行的.
在nodejs目录下创建一个模块文件*.js,以便调用,
以下是模块代码:...
mongodb操作的模块手动封装
[注]:这些代码都是基于nodejs进行的.
在nodejs目录下创建一个模块文件*.js,以便调用,
以下是模块代码:
function mongodbmodel(dbname,dataform) { var mongoclient; var db_conn_str; this.init = function() { mongoclient = require('mongodb').mongoclient; db_conn_str = 'mongodb://localhost:27017/' + dbname; } /*这里是插入数据*/ this.insert = function(data,callback) { mongoclient.connect(db_conn_str, function(err, db) { console.log('连接成功') var collection = db.collection(dataform); collection.insert(data, function(err,result){ callback(err,result); }) }) } /*这里是删除数据*/ this.remove = function(data,callback){ mongoclient.connect(db_conn_str, function(err, db) { console.log('连接成功') var collection = db.collection(dataform); collection.remove(data, function(err,result){ callback(err,result); }) }) } /*这里是修改*/ this.update=function(data,updata,callback){ mongoclient.connect(db_conn_str, function(err, db) { console.log('连接成功') var collection = db.collection(dataform); collection.update(data,updata,function(err,data){ callback(err,data); }) }) } /*这里是查询*/ this.find=function(data,callback){ mongoclient.connect(db_conn_str, function(err, db) { console.log('连接成功') var collection = db.collection(dataform); collection.find(data).toarray(function(err,data){ callback(err,data); }) }) } } module.exports = mongodbmodel;
如何使用:
在同目录下创建一个调用文件*.js
var mongodbmodel = require('./mongodbmodel'); var mongodbobject = new mongodbmodel('seraph','singer'); mongodbobject.init(); /*这里是插入*/ mongodbobject.insert({name:'啊xx'},function(err,data){ if(err){ console.log(err); }else{ console.log(data); } }) /*这是删除*/ mongodbobject.remove({name:'啊xiao'},function(err,data){ if(err){ console.log(err); }else{ console.log('成功删除指定数据'); } }) /*这里是修改*/ mongodbobject.update({name:'小李'},{$set:{name:'小勇'}},function(err,data){ if(err){ console.log(err); }else{ console.log(data); } }) /*这里是条件查询*/ mongodbobject.find({name:'李洛克'},function(err,data){ if(err){ console.log(err); }else{ console.log(data); } })
相关参数:
dbname:是指要操作的database;
dataform:是指要操作的数据表;
data:表示需要插入或者查询或者修改的数据;
updata:表示修改后的数据;
个人在封装的时候,callback()是个难点
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!