首页 > 解决方案 > 在vercel部署中下一个js prisma未定义

问题描述

所以...我在 Next js 中有一个使用 Prisma Client 的 api。Prisma 是从 prisma.ts 中定义的全局对象导入的

在本地,一切都构建并运行良好。我没有收到任何错误,并且定义了 prisma 变量。但是,当它部署在 Vercel 中时,prisma 是未定义的……我不知道为什么。

如果有人有任何建议,我将不胜感激。

import eBayApi from "@hendt/ebay-api";
import prisma from "../../lib/prisma";

const eBay = new eBayApi({});

export default async (req, res) => {
  // Access the provided 'page' and 'limt' query parameters
  const code = req.query.code; // this is provided from eBay
  console.log(code);

  try {
    //const token = await eBay.OAuth2.getToken(code);
    const token = "bob";

    console.log("Prisma handler instance", prisma);

    const env_variable = await prisma.variable.upsert({
      where: {
        variable: "EBAY_TOKEN",
      },
      update: { value: token },
      create: {
        variable: "EBAY_TOKEN",
        value: token,
      },
    });

    if (env_variable) {
      console.log("New Token Stored in DB");
    } else console.log("Failed to store new Token");

    res.status(200);
    res.writeHead(302, {
      Location: "/orders",
      //add other headers here...
    });
    res.end();
  } catch (e) {
    console.error(e);
    res.status(400).end();
  }

  res.writeHead(302, {
    Location: "/orders",
    //add other headers here...
  });
  res.end();
};

2021-04-18T19:06:18.680Z 869eb228-423a-4d6a-b05a-f95f5e843c88 错误类型错误:无法读取 export.modules.5712 中未定义的属性“upsert”。webpack_exports.default (/var/task/nextjs-store/.next/server/pages/api/success.js:55:126) at processTicksAndRejections (internal/process/task_queues.js:93:5) at async apiResolver (/var /task/nextjs-store/node_modules/next/dist/next-server/server/api-utils.js:8:1) 在异步 Server.handleApiRequest (/var/task/nextjs-store/node_modules/next/dist/ next-server/server/next-server.js:67:462) 在异步 Object.fn (/var/task/nextjs-store/node_modules/next/dist/next-server/server/next-server.js:59 :492) 在异步 Server.run (/var/task/nextjs) 处异步 Router.execute (/var/task/nextjs-store/node_modules/next/dist/next-server/server/router.js:25:67) -store/node_modules/next/dist/next-server/server/next-server.js:69:1042) 在异步 Server.handleRequest (/var/task/nextjs-store/node_modules/next/dist/next-server/ server/next-server.js:34:504) 在异步服务器上。(/var/task/nextjs-store/___next_launcher.js:26:9)

标签: node.jsnext.jsprismavercel

解决方案


所以,我玩了一下,认为我找到了问题所在。我的 prisma 表字段是一个 VARCHAR(字符串),但是我无意中尝试使用 JSON 对象存储 upsert。现在我已更改为 JSON 字段,它正在工作。

所以我想唯一的问题是错误可能没有帮助?虽然这都是我愚蠢的错。


推荐阅读