我从 Prisma 1 升级到 Prisma 2 时遇到问题。文档对我来说相当复杂。我目前有一个小项目使用:
"dependencies": {
"bcryptjs": "2.4.3",
"graphql-yoga": "1.18.3",
"jsonwebtoken": "8.5.1",
"prisma-binding": "1.5.19"
},
"devDependencies": {
"dotenv": "5.0.1",
"graphql-cli": "2.17.0",
"nodemon": "1.19.4",
"npm-run-all": "4.1.5",
"prisma": "^1.34.10"
}
我的 prisma.yml :
endpoint: ${env:PRISMA_ENDPOINT}
secret: ${env:PRISMA_SECRET}
datamodel: datamodel.graphql
hooks:
post-deploy:
- prisma generate
generate:
- generator: graphql-schema
output: ../src/generated/prisma.graphql
我使用了脚本:
"scripts": {
"start:dev": "nodemon -e js,graphql -x node -r dotenv/config src/index.js",
"start": "node src/index.js",
"debug": "nodemon -e js,graphql -x node --inspect -r dotenv/config src/index.js",
"playground": "graphql playground",
"dev": "npm-run-all --parallel start playground",
"deploy": "prisma1 deploy --env-file .env"
},
而这个graphqlconfig
projects:
app:
schemaPath: "src/schema.graphql"
extensions:
endpoints:
default: "http://localhost:4000"
prisma:
schemaPath: "src/generated/prisma.graphql"
extensions:
prisma: database/prisma.yml
如何更新棱镜?知道我的前端是基于带有 ApolloClient、graphlq、graphql-tag 的 VueJS
非常感谢你,后端部分对我来说并不简单
编辑
谢谢你的回答。不错,@nburk
但是我在第三步遇到了问题:https ://www.prisma.io/docs/guides/upgrade-guides/upgrade-from-prisma-1/upgrading-the-prisma-layer-postgres
(连接网址)
以前我不使用“docker-compose”。我使用 Prisma 在 Heroku 上部署了我的 front + back + DB
const { Prisma } = require("prisma-binding");
const resolvers = require("./resolvers");
// GraphQL Yoga Server
const server = new GraphQLServer({
typeDefs: "src/schema.graphql",
resolvers,
context: (req) => ({
...req,
db: new Prisma({
typeDefs: "src/generated/prisma.graphql", // DB Prisma Schema
endpoint: process.env.PRISMA_ENDPOINT, // Prisma Service
secret: process.env.PRISMA_SECRET, // Prisma Secret
debug: true,
}),
}),
});
server.start(() =>
console.log(`Server is running on ${process.env.PRISMA_ENDPOINT}`)
);
使用 Heroku 上托管的数据库(.env 文件)
PRISMA_ENDPOINT="https://lprojet-name-db.herokuapp.com/database/prod"
当我使用 npx prisma introspect 我有这个错误
Introspecting based on datasource defined in prisma/schema.prisma …
Error: P1001
无法访问 ''localhosh':'5432' 的数据库服务器
请确保您的数据库服务器在 'localhost':'5432' 上运行我认为问题来自 schema.prisma 它需要有一个以 postgresql:// 开头的 url 但使用 Prisma1 我不需要经历那个.
如何转换我的旧数据库 URL(当前托管在 Heroku 上)?
谢谢
编辑 2
我用了
DATABASE_URL=postgres://..........eu-west-1.compute.amazonaws.com:5432/d9ptc61fera9g1
我有一个“数据库为空”的错误,但我的数据库不是空的。这个 UR 来自 Heroku 数据库配置