[TOC]
### 模型静态属性
* [ ] model 定义一个模型
~~~
'use strict';
module.exports = app => {
const { STRING, INTEGER, DATE } = app.Sequelize;
const Post = app.model.define('post', {
id: {
type: INTEGER,
primaryKey: true,
autoIncrement: true,
},
title: STRING(30),
content: STRING(255),
user_id: INTEGER,
created_at: DATE,
updated_at: DATE,
});
// 模型实例添加关联
Post.associate = function() {
app.model.Post.belongsTo(app.model.User, { as: 'user', foreignKey: 'user_id' });
};
// 模型实例添加静态方法
Post.findByIdWithUser = async function(id, userId) {
return await this.findOne({
where: { id, user_id: userId },
});
};
return Post;
};
~~~
调用:
~~~
async update({ id, user_id, updates }) {
const post = await this.ctx.model.Post.findByIdWithUser(id, user_id);
if (!post) this.ctx.throw(404, 'post not found');
return post.update(updates);
}
~~~
~~~
async find(id) {
const post = await this.ctx.model.Post.findByPk(id, {
include: [{
model: this.ctx.model.User,
as: 'user',
attributes: [ 'id', 'name', 'age' ],
}],
});
if (!post) {
this.ctx.throw(404, 'post not found');
}
return post;
}
~~~
- 概述
- 起步
- 跨域配置
- 路径别名
- 路由
- api版本控制
- 错误和异常
- 全局异常处理
- 数据库
- 创建迁移文件
- sequelize数据类型
- 配置
- 新增
- 查询
- 条件查询
- 模糊查询
- 排序查询
- 聚合查询
- 分组查询
- 分页查询
- 修改
- 删除
- 获取器
- 修改器
- 静态属性
- 字段验证
- 外键约束
- 关联模型
- 一对一
- 一对多
- 左外连接
- 多对多
- 字段显示隐藏
- 事务
- 字段自增
- 验证层
- egg-validate
- indicative验证器
- egg-validate-plus
- betterValidate
- 校验规则
- 中间件
- 安全
- 数据加密
- 单向加密
- 示例代码
- 封装egg加密
- 上传
- path模块
- 单文件上传
- 多文件上传
- 按照日期存储
- 工具函数
- egg常用工具函数
- 缓存
- 配置缓存插件
- 设置缓存
- 获取缓存
- 删除缓存
- 消息队列
- rabbitMQ
- 安装
- 简单队列
- 工作队列
- 工作队列(dispach分发)
- 消息应答和持久化
- redis
- 数据类型
- 字符串类型(String)
- 哈希类型(Hash)
- 列表(List)
- 无序集合(Set)
- 可排序集合(Zset)
- 邮件系统
- nodeMailer
- 第三方模块
- 生成随机数
- JWT
- JWT鉴权
- 生成Token
- 短信服务
- 阿里大鱼短信验证码
- 发送短信逻辑
- 阿里短信Node类