如何解决Next js、Knex 和 SWR 的奇怪查询错误
使用 Next
API 路由和 Knex
+ MysqL
,并使用 React
和 SWR
进行获取,我遇到了一个奇怪的错误。如果请求失败,我的查询开始将 ,*
附加到 select
语句,从而导致 sql 语法错误。例如,查询应使用 select *
,但结果为 select *,*
,然后是 select *,*,*
,依此类推。有没有人知道为什么会发生这种情况?
SWR 获取:
export const swrFetcher = async (...args) => {
const [url,contentType = 'application/json'] = args;
const res = await fetch(url,{
method: 'GET',headers: {
'Content-Type': contentType,},});
if (!res.ok) throw new Error(res.statusText);
const json = await res.json();
return json;
};
const { data,error } = useSWR('/api/user/me',swrFetcher,{
revalidateOnFocus: false,revalidateOnReconnect: false,revalidateOnMount: true,});
膝关节查询:
const User = knex(TABLE_NAMES.user);
export const readById = (id) => User.select('*').where({ id });
解决方法
您可能需要在函数调用中创建 knex
实例,而不是每次都重用相同的实例,就像当前发生的那样。
export const readById = (id) => {
const User = knex(TABLE_NAMES.user);
return User.select('*').where({ id });
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。