ThinkJS中如何使用MongoDB的CURD操作
程序员文章站
2024-01-04 13:29:04
前言
众所周知目前使用node.js + mongodb已经成为很多公司的技术栈。thinkjs其实也提供了对mongo的支持,虽然较少,但是保证了orm的api的一致性...
前言
众所周知目前使用node.js + mongodb已经成为很多公司的技术栈。thinkjs其实也提供了对mongo的支持,虽然较少,但是保证了orm的api的一致性,所以用起来需要查看基本的>model api
基本的模型文件放在common/model下
获取列表
getlist(q, page) { return this.select(); }
分页加条件搜索
search(q, page) { if(q) { q = new regexp(q,'i'); } return this.where({'name':{ $regex: q}}).page(page, 20).countselect(); }
获取详情
getdetail(id) { return this.where({'_id':id}).select(); }
创建数据
addtag(tag) { return this.add(tag); }
更新数据
updatetag(id,data) { return this.where({'_id':id}).update(data); }
删除数据
removeone(id) { return this.where({'_id':id}).delete(); }
这样你需要什么只需要调用相应模型的方法就好了。
一个简单的接口如下:
async createaction() { let name = this.post('name'); let contents = this.post('contents'); // 获取模型实例 let m = this.model('tag'); let res = await m.addtag({ 'name': name, 'contents': contents, 'count': 0, }); if(res) { this.success(''); }else{ this.apierrorhandle(4000); } } ....
总结
以上就是这篇文章的全部内容改了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。