- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
背景
Error: Order must be type of array or instance of a valid sequelize method
我以为我已经解决了这个问题,但结果我又搞砸了这个错误。
sequelize.literal()
来绕过这个问题。
Model.function(options)
.此选项对象在方法函数内部进行验证,如果它需要以某种方式进行突变。 Model.findAll(options)
const sequelize = require('sequelize')
const { ModelA } = require('../models')
...
router.get('/', ..., async (req, res, next) => {
try {
...
if(page < lastpage + 1){
const products = await ModelA.classMethod({
subquery : false,
include: [
...
],
...
order : sequelize.literal(`"Product.rating" DESC`)
})
...
}
...
} catch (e) {
...
}
})
类方法
ModelA.classMethod = async function(options){
const sequelize = require('sequelize')
const { ModelB } = require('.')
let { include, where, order, limit, offset, product } = options
...
const items = await ModelA.findAll({
subquery: false,
include: [
{
model: ModelB,
as: 'ModelB',
required: true,
where: product.where,
include: include
}
],
where: where,
limit: limit,
order: order
})
...
}
奇怪的事情正在这里发生。传递参数时(模式 3),出现错误
Error: Order must be type of array or instance of a valid sequelize method
这个错误似乎是因为传递的选项无效
sequelize.literal()
但实际上我通过的只是
sequelize.literal(`'Product.name' DESC`)
,这里没有突变。
let { order } = option
console.log(order)//Literal { val: "'Product.rating' DESC" }
console.log(order instanceof sequelize.Utils.SequelizeMethod)//false
if(!order) order = null
console.log(order)//Literal { val: "'Product.rating' DESC" }
ModelA.findAll({ ..., order : order })
console.log('good!!!')//I want to see this log
订单本身看起来不错,但我认为原型(prototype)的某个地方坏了。
sequelize.literal(`'Product.name' DESC`)
,这与我传递给 classMethod 参数的内容相同,发生了某种魔术并且错误消失了。
const sequelize = require('sequelize')
let order = sequelize.literal("'Product.rating'")
console.log(order)//Literal { val: "'Product.rating' DESC" }
console.log(order instanceof sequelize.Utils.SequelizeMethod)//true!!
if(!order) order = null
ModelA.findAll({ ..., order : order })
console.log('good!!!')//I see this log and I can finally rest in peace.
console.log(order instanceof sequelize.Utils.SequelizeMethod)//true
所以似乎没有破坏实际查询没有以某种方式执行。 order : sequelize.literal("'Product.rating' DESC")
:工作完美,但在生产中无用。此选项应该是动态的,以便用户可以控制它。 最佳答案
我的坏奇怪的不是错误,而是我在应用程序和项目根目录之间使用了不同的版本。此问题是由 引起的嵌套目录的版本问题 .
/* MY PROJECT STRUCTURE */
project
|
|--api (sequelize 5.22)
|
|--auth
|
|--batch
|
|-- models (sequelize 6.3)
最近,我将 sequelize 从 5.22 升级到 6.3,同时这样做,我错过了升级应用程序的 sequelize。所以根和应用程序之间的版本是不同的。由于 sequelize 正在迁移到 typescript,因此 6.0 和 5.22 的 sequelize 内部类型必须不同。
Error: Order must be type of array or instance of a valid sequelize method
所以,这个错误是足够合理的,但我现在无法理解。有很多建议不要在嵌套目录中安装相同的模块。我应该仔细听他们的。
[model, 'column', 'type']
)给了我错误的查询并最终导致未知列错误。
关于node.js - Option.order 在传递给类方法时被破坏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65303310/
我经常使用 var options = options || {} 作为默认为空对象的方式。它通常用于初始化选项对象,以防它未在函数调用的参数中传递。 问题是我在几个地方(博客文章、源代码)读到opt
我是Python中Rust的新手。这是我学习Rust的第四天。 在第一个问题Type casting for Option type之后,我有一个跟语法match和所有权概念有关的后续问题。 首先,我
我正在学习 Ray Wenderlich。我遇到了闭包语法错误。我想知道 Xcode 提示是什么意思? Xcode 报告如下: /Users/.../FlickrPhotosViewControlle
使用 Python 编写命令行界面 (CLI) 时 click library , 是否可以定义例如三个选项,其中仅当第一个(可选)未设置时才需要第二个和第三个选项? 我的用例是一个登录系统,它允许我
我有一个这样的 JPA 查询。 PersonRepository.java public Optional> findByStatus(int status); 人员服务.java System.ou
我遇到了很多地方,我有类似的东西 def f(s: String): Option[Long] = ... def g(l: Long): IO[Option[Wibble]] = ... val a
我有一个results: List[Future[Option[T]]]其中包含(并行)计算。 我想获得第一个非None尽快出结果,或者返回None如果所有计算都返回 None . 目前,我正在这样做
我正在尝试加载一个简单的 Listbox组件来自 @headlessui/react . 选择.tsx type Option = { id: number name: string
如何将Future[Option[Future[Option[X]]]]转换为Future[Option[X]]? 如果它是 TraversableOnce 而不是 Option 我会使用 Futur
Haskell、Rust 等语言提供了一个 Maybe 或 Option 类型。即使在 Java 中,也有一个 Optional 现在打字。 为简单起见,我将在剩下的问题中将此类型称为“选项类型”。
当我尝试在 SQL 中存储一个 XML 而不是一个空元素时,SQL 只是更改它并仅使用一个元素标签来存储它。例如,要存储的 XML 是: ROGER 然后Sql存起来就好了
使用这个非常好的命令行解析器 Argo(仅 header C++ 库)我遇到了一个小问题。请参阅:https://github.com/phforest/Argo Argo 返回:'Error: Un
我是来自 Java 背景的 Scala 新手,目前对考虑 Option[T] 的最佳实践感到困惑. 我觉得用 Option.map只是更实用和美观,但这不是说服其他人的好理由。有时, isEmpty
这个问题在这里已经有了答案: Chaining Optionals in Java 8 (9 个回答) Optional orElse Optional in Java (6 个回答) Functio
Optional::stream如果存在,则返回一个包含该值的 Stream,否则返回一个空流。所以对于 Stream> optionals , optionals.flatMap(Optional:
我使用箭头键作为输入,在 printf 菜单中上下移动 printf 箭头(“==>”)。 我正在使用一个函数来计算箭头应该在的位置,并使用 switch case 和 printf("\n==>")
这个问题在这里已经有了答案: What does the construct x = x || y mean? (12 个答案) 关闭 9 年前。 如我的问题标题所述,我最近偶然发现了这个变量声明:
这个问题在这里已经有了答案: BackboneJS: What is options || (options = {}); in Backbone source code (1 个回答) 关闭 8
我有这个简单的语法: word = Word(alphanums + '_') with_stmt = Suppress('with') + OneOrMore(Group(word('key') +
使用 Cucumber 和 SitePrism 编写测试,我在页面上有以下 HTML... Select a Status Active Product Inactive Prod
我是一名优秀的程序员,十分优秀!