返回 ThinkJS...... 登陆

ThinkJS中如何使用MongoDB的CURD操作

巴扎黑 2016-12-26 14:12:24 273

前言

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

   

总结

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


最新手记推荐

• 用composer安装thinkphp框架的步骤 • 省市区接口说明 • 用thinkphp,后台新增栏目 • 管理员添加编辑删除 • 管理员添加编辑删除

全部回复(0)我要回复

暂无评论~
  • 取消 回复 发送
  • PHP中文网