ThinkJS中如何使用MongoDB的CURD操作

最近因为心血来潮想要试试thinkJS操作mongoDB,去官方文档看了看,默认是只给了mysql的配置,源代码也是没有配置mongo的,只有一个官方案例,无奈只能自己学习了,下面是自己的一些学习总结,有需要的朋友们可以参考借鉴,下面来一起看看吧。

前言

众所周知目前使用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); } } ....

总结

以上就是这篇文章的全部内容改了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwfjfd.html