目前有个系统,架构是 koa+mysql(历史原因,没有使用 mongdb),为了便于扩展,mysql 表里面用了很多类似名为 detail/tags 的 json 类型字段.
例如有个 users 表,包含了 tags 字段,保存该用的额 tag, 例如['可爱','型男','80 后']等数据.在 koa 读取这个用户的时候:
const user = await this.model('users').where({id: 1}).find();
读取的结果,user.tags 是一个 string 类型的值,而不是标准的 json array. 当然手工可以转换成 json,但是如果字段多的话,就会很累.
刚刚接触 nodejs,不知道有没有自动化的处理方法,让框架能自动识别 model 中的 json fields 类型,自动转换成 json 类型?
1
noe132 2018 年 2 月 23 日 via Android
自己写中间件转换呗。。。mysql 和 node 又不知道你的 string 是不是合法的 json string,mysql 也没有 json 这个类型
|
3
zenxds 2018 年 2 月 23 日
model 里面写 getter 吧
|
4
feichao 2018 年 2 月 26 日
暴力一点的方法可以 hack 一下原型链,找到 find 方法对应的构造函数,然后在原型上添加一个方法,大概就像这个样子:
XXX.prototype.findAndConvertToArray = async function () { const stringValue = await this.find() return JSON.parse(stringValue) } |
5
feichao 2018 年 2 月 26 日
在原型链上添加方法之后就可以像 find 一样调用 findAndConvertToArray 方法了。不过记得给新增的方法加上注释,防止别人不理解。
|
6
skyworker OP @feichao 是的,目前采用的就是这种办法. 原以为 koajs 之类的框架,应该有自动 convert 的 feature,看来没有了
|
7
vcfvct 2018 年 3 月 3 日 via Android 可以看看 typeorm 里有没有好的方案,converter 或者 mapper 之类的。
|