微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Next js、Knex 和 SWR 的奇怪查询错误

如何解决Next js、Knex 和 SWR 的奇怪查询错误

使用 Next API 路由和 Knex + MysqL,并使用 ReactSWR 进行获取,我遇到了一个奇怪的错误。如果请求失败,我的查询开始将 ,* 附加到 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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?