已删除对“{where: 'raw query'}”的支持
Support for `{where: 'raw query'}` has been removed
我正在 运行使用 AWS Lambda 上的无服务器框架构建一个 GraphQL 服务器。
我正在使用 apollo-link-batch-http
.
在 UI 中获取数据
如果我 运行 在本地使用 serverless-offline
,它工作正常。但是,如果我在 AWS Lambda 上 运行 它,它会成功解析 fooResolver
而不是 barResolver
,因为它会抛出上述错误消息。
Model.cached(300)
是我制作的一个小型缓存包装器。你可以在这里看到它:
https://gist.github.com/lookapanda/4676083186849bb6c5ae6f6230ad7d8f
它基本上只是让我能够使用我自己的 findById
函数等等。
奇怪的是,如果我使用 apollo-link-batch-http
只会出现此错误,但如果我使用 apollo-link-http
则不会出现。因此,如果将请求批处理为单个 GraphQL 请求,则不会出现此类错误(尽管如此,我会收到此错误:https://github.com/sequelize/sequelize/issues/9242)
我真的不知道那里发生了什么,在任何这些解析器中都没有原始的 where 查询。它变得更奇怪:它只发生在缓存的结果上。第一个请求完全有效且成功,但随后每个连续请求都失败并显示上述错误消息。
我真的希望有人能帮助我,我快疯了:D
export const fooResolver = async () => {
const Model = db.getDB().sequelize.models.fooModel;
const data = await Model.cached(300).findAll({
where: {
time: {
[Op.gt]: Model.sequelize.literal('CURRENT_TIMESTAMP()'),
},
enabled: true,
state: 'PLANNED',
},
order: [['time', 'DESC']],
limit: 5,
});
return data.value;
};
export const barResolver = async () => {
const models = db.getDB().sequelize.models;
const Model = models.fooModel;
const data = await Model.findById(data.id, {
include: [
{
model: models.barModel,
include: [
{
association: 'fooAssociation',
include: [{ association: 'barAssociation' }],
order: ['showOrder', 'ASC'],
},
],
},
],
});
return {
data,
};
};
好的,经过繁琐的调试后,我发现在可缓存的包装器中我使用了这个片段:
https://github.com/sequelize/sequelize/issues/2325#issuecomment-366060303
我仍然不太清楚,为什么这个错误只出现在 Lambda 而不是本地,但是当我只使用 selectQuery()
方法并且只返回它而不是整个 Model.addHook
东西等等。所以基本上改变了这个
export const getSqlFromSelect = (Model, method, args) => {
if (!SUPPORTED_SELECT_METHODS.includes(method)) {
throw new Error('Unsupported method.');
}
const id = generateRandomHash(10);
return new Promise((resolve, reject) => {
Model.addHook('beforeFindAfterOptions', id, options, => {
Model.removeHook('beforeFindAfterOptions', id);
resolve(
Model.sequelize.dialect.QueryGenerator.selectQuery(
Model.getTableName(),
options,
Model
).slice(0, -1)
);
});
return Model[method](...args).catch(reject);
});
};
至此
export const getSqlFromSelect = (Model, identifier, options) => {
if (typeof identifier === 'number' || typeof identifier === 'string' || Buffer.isBuffer(identifier) {
options.where = {
[Model.primaryKeyAttribute]: identifier,
};
};
return Model.sequelize.dialect.QueryGenerator.selectQuery(
Model.getTableName(),
options,
Model
).slice(0, -1);
};
我遇到了类似的情况,除了在我的情况下使用下面的代码效果很好:
.findAll({
where: {
title: req.params.title
}
})
我正在 运行使用 AWS Lambda 上的无服务器框架构建一个 GraphQL 服务器。
我正在使用 apollo-link-batch-http
.
如果我 运行 在本地使用 serverless-offline
,它工作正常。但是,如果我在 AWS Lambda 上 运行 它,它会成功解析 fooResolver
而不是 barResolver
,因为它会抛出上述错误消息。
Model.cached(300)
是我制作的一个小型缓存包装器。你可以在这里看到它:
https://gist.github.com/lookapanda/4676083186849bb6c5ae6f6230ad7d8f
它基本上只是让我能够使用我自己的 findById
函数等等。
奇怪的是,如果我使用 apollo-link-batch-http
只会出现此错误,但如果我使用 apollo-link-http
则不会出现。因此,如果将请求批处理为单个 GraphQL 请求,则不会出现此类错误(尽管如此,我会收到此错误:https://github.com/sequelize/sequelize/issues/9242)
我真的不知道那里发生了什么,在任何这些解析器中都没有原始的 where 查询。它变得更奇怪:它只发生在缓存的结果上。第一个请求完全有效且成功,但随后每个连续请求都失败并显示上述错误消息。
我真的希望有人能帮助我,我快疯了:D
export const fooResolver = async () => {
const Model = db.getDB().sequelize.models.fooModel;
const data = await Model.cached(300).findAll({
where: {
time: {
[Op.gt]: Model.sequelize.literal('CURRENT_TIMESTAMP()'),
},
enabled: true,
state: 'PLANNED',
},
order: [['time', 'DESC']],
limit: 5,
});
return data.value;
};
export const barResolver = async () => {
const models = db.getDB().sequelize.models;
const Model = models.fooModel;
const data = await Model.findById(data.id, {
include: [
{
model: models.barModel,
include: [
{
association: 'fooAssociation',
include: [{ association: 'barAssociation' }],
order: ['showOrder', 'ASC'],
},
],
},
],
});
return {
data,
};
};
好的,经过繁琐的调试后,我发现在可缓存的包装器中我使用了这个片段: https://github.com/sequelize/sequelize/issues/2325#issuecomment-366060303
我仍然不太清楚,为什么这个错误只出现在 Lambda 而不是本地,但是当我只使用 selectQuery()
方法并且只返回它而不是整个 Model.addHook
东西等等。所以基本上改变了这个
export const getSqlFromSelect = (Model, method, args) => {
if (!SUPPORTED_SELECT_METHODS.includes(method)) {
throw new Error('Unsupported method.');
}
const id = generateRandomHash(10);
return new Promise((resolve, reject) => {
Model.addHook('beforeFindAfterOptions', id, options, => {
Model.removeHook('beforeFindAfterOptions', id);
resolve(
Model.sequelize.dialect.QueryGenerator.selectQuery(
Model.getTableName(),
options,
Model
).slice(0, -1)
);
});
return Model[method](...args).catch(reject);
});
};
至此
export const getSqlFromSelect = (Model, identifier, options) => {
if (typeof identifier === 'number' || typeof identifier === 'string' || Buffer.isBuffer(identifier) {
options.where = {
[Model.primaryKeyAttribute]: identifier,
};
};
return Model.sequelize.dialect.QueryGenerator.selectQuery(
Model.getTableName(),
options,
Model
).slice(0, -1);
};
我遇到了类似的情况,除了在我的情况下使用下面的代码效果很好:
.findAll({
where: {
title: req.params.title
}
})