2

所以

安慰:

yarn dev
yarn run v1.22.10
$ nodemon dist/index.js
[nodemon] 2.0.7
[nodemon] to restart at any time, enter `rs`
[nodemon] watching path(s): *.*
[nodemon] watching extensions: js,mjs,json  
[nodemon] starting `node dist/index.js`     
[discovery] ORM entity discovery started, using ReflectMetadataProvider
[discovery] - processing entity Post
[discovery] - entity discovery finished, found 1 entities, took 21 ms
[info] MikroORM successfully connected to database postgres on postgresql://postgres:*****@127.0.0.1:5432
[query] begin
[query] insert into "post" ("created_at", "title", "updated_at") values ('2021-04-05T21:04:23.126Z', 'my first post', '2021-04-05T21:04:23.126Z') returning "_id" [took 12 ms]
[query] rollback
TableNotFoundException: insert into "post" ("created_at", "title", "updated_at") values ('2021-04-05T21:04:23.126Z', 'my first post', '2021-04-05T21:04:23.126Z') returning "_id" - relation "post" does not exist
    at PostgreSqlExceptionConverter.convertException (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\postgresql\PostgreSqlExceptionConverter.js:36:24)
    at PostgreSqlDriver.convertException (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\drivers\DatabaseDriver.js:194:54)
    at P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\drivers\DatabaseDriver.js:198:24
    at processTicksAndRejections (internal/process/task_queues.js:93:5)
    at async PostgreSqlDriver.nativeInsert (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\knex\AbstractSqlDriver.js:150:21)
    at async ChangeSetPersister.persistNewEntity (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\unit-of-work\ChangeSetPersister.js:55:21)
    at async ChangeSetPersister.executeInserts (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\unit-of-work\ChangeSetPersister.js:24:13)
    at async UnitOfWork.commitCreateChangeSets (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\unit-of-work\UnitOfWork.js:496:9)
    at async UnitOfWork.persistToDatabase (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\unit-of-work\UnitOfWork.js:458:13)
    at async PostgreSqlConnection.transactional (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\knex\AbstractSqlConnection.js:53:25)
    at async UnitOfWork.commit (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\unit-of-work\UnitOfWork.js:183:17)
    at async SqlEntityManager.flush (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\EntityManager.js:486:9)
    at async SqlEntityManager.persistAndFlush (P:\.Projektek\lireddit-server\node_modules\@mikro-orm\core\EntityManager.js:438:9)

previous error: insert into "post" ("created_at", "title", "updated_at") values ('2021-04-05T21:04:23.126Z', 'my 
first post', '2021-04-05T21:04:23.126Z') returning "_id" - relation "post" does not exist
    at Parser.parseErrorMessage (P:\.Projektek\lireddit-server\node_modules\pg-protocol\dist\parser.js:278:15)   
    at Parser.handlePacket (P:\.Projektek\lireddit-server\node_modules\pg-protocol\dist\parser.js:126:29)        
    at Parser.parse (P:\.Projektek\lireddit-server\node_modules\pg-protocol\dist\parser.js:39:38)
    at Socket.<anonymous> (P:\.Projektek\lireddit-server\node_modules\pg-protocol\dist\index.js:10:42)
    at Socket.emit (events.js:315:20)
    at Socket.EventEmitter.emit (domain.js:467:12)
    at addChunk (internal/streams/readable.js:309:12)
    at readableAddChunk (internal/streams/readable.js:284:9)
    at Socket.Readable.push (internal/streams/readable.js:223:10)
    at TCP.onStreamRead (internal/stream_base_commons.js:188:23) {
  length: 166,
  severity: 'ERROR',
  code: '42P01',
  detail: undefined,
  hint: undefined,
  position: '13',
  internalPosition: undefined,
  internalQuery: undefined,
  where: undefined,
  schema: undefined,
  table: undefined,
  column: undefined,
  dataType: undefined,
  constraint: undefined,
  file: 'd:\\pginstaller_13.auto\\postgres.windows-x64\\src\\backend\\parser\\parse_relation.c',
  line: '1376',
  routine: 'parserOpenTable'
}

索引.ts:

import { MikroORM } from "@mikro-orm/core";
import { __prod__ } from "./constants";
import { Post } from "./entities/Post";
import mikroConfig from "./mikro-orm.config";

const main = async () => {
  const orm = await MikroORM.init(mikroConfig);
  await orm.getMigrator().up;
  const post = orm.em.create(Post, { title: "my first post" });
  await orm.em.persistAndFlush(post);
};

main().catch((err) => {
  console.error(err);
});

Post.ts:

import { Entity, PrimaryKey, Property } from "@mikro-orm/core";

@Entity()
export class Post {
  @PrimaryKey()
  _id!: number;

  @Property({ type: "date" })
  createdAt = new Date();

  @Property({ type: "date", onUpdate: () => new Date() })
  updatedAt = new Date();

  @Property({ type: "text" })
  title!: string;
}

mikro-orm.config.ts:

import { __prod__ } from "./constants";
import { Post } from "./entities/Post";
import { MikroORM } from "@mikro-orm/core";
import path from "path";

export default {
  migrations: {
    path: path.join(__dirname, "./migrations"),
    pattern: /^[\w-]+\d+\.[tj]s$/,
  },
  entities: [Post],
  dbName: "postgres",
  debug: !__prod__,
  type: "postgresql",
  password: "hellothere",
} as Parameters<typeof MikroORM.init>[0];

以及我使用 npx mikro-orm migration:create 创建的迁移:

import { Migration } from '@mikro-orm/migrations';

export class Migration20210405205411 extends Migration {

  async up(): Promise<void> {
    this.addSql('create table "post" ("_id" serial primary key, "created_at" timestamptz(0) not null, "updated_at" timestamptz(0) not null, "title" text not null);');
  }

}

在那之后我将它编译为 js btw,但我想问题将出在我的代码或 idk 的某个地方,请帮助我,我可以为你提供更多信息,请帮助,我已经尝试修复这个错误 5 小时:/

顺便说一句,我正在做 Ben Awad 的 14 小时全栈教程(如果有的话)。

4

6 回答 6

4

TableNotFoundException当您在初始化表的架构(或结构)之前尝试添加数据时会发生这种情况。

在Mosh's Answer中传递--initialas对我不起作用,可能是因为我在../mikro-orm.config.ts

我使用 Mikro-ORM 的 SchemaGenerator 来初始化表,如官方文档中所示。


在将数据添加到您的主函数中之前添加以下行index.ts

const generator = orm.getSchemaGenerator();
await generator.updateSchema();

中的主要功能index.ts现在应该如下所示:

const main = async () => {
  const orm = await MikroORM.init(mikroConfig);    
  await orm.getMigrator().up;

  const generator = orm.getSchemaGenerator();
  await generator.updateSchema();

  const post = orm.em.create(Post, { title: "my first post" });
  await orm.em.persistAndFlush(post);
};

updateSchema创建一个表或基于 更新它.entities/Post.ts。这可能会在更新 Post 文件时导致问题,我在遵循 Ben 的教程时没有遇到任何问题。虽然,我仍然建议./create-schema.ts在需要时创建并运行它,如官方文档中所示。

于 2021-06-12T17:22:28.863 回答
3

我有同样的问题。这就是我所做的:

  1. 我删除了migrations文件夹以及dist文件夹
  2. 我跑了npx mikro-orm migration:create --initial

之后,我重新启动yarn watch并且yarn dev它对我有用。

注意--initial国旗。我建议查看官方文档。迁移表用于跟踪已执行的迁移。当您只运行npx mikro-orm migration:create时,不会创建表,因此 MikroORM 无法检查 Post 实体的迁移是否已经执行(包括在数据库上创建相应的表)。

Ben 在他的教程中没有使用该--initial标志,他可能在教程之前已经运行过它。

于 2021-04-22T20:32:56.023 回答
2

我自己也有类似的问题(也在做 Ben Awad 的教程)。

我使用 Mikro-ORM 的模式生成器来初始化表,就像在Fares47 的 Answer中一样,但问题仍然存在。

直到我将我的用户设置为具有超级用户权限,它才开始工作。

我正在使用 postgresql 作为我使用自制软件下载的数据库。如果您有类似的设置,我就是这样做的:

使用 . 在终端中启动 psql psql postgres。如果需要,您可以通过\du在 shell 中键入来查看您的用户并检查他们的权限。然后,要更改用户的权限,请使用命令ALTER ROLE <username> WITH SUPERUSER;。确保包含分号,否则它将不会运行该命令。

查看本文以获取有关 psql 命令的更多信息。

于 2021-07-01T20:54:23.617 回答
1

我通过在项目上安装 ts-node 解决了同样的问题

npm i -D ts-node

并将 package.json 上的 useTsNode 设置为 true。

问题是 mikro-orm cli 仅在属性 useTsNode 为 true 并且安装了 ts-node 时在 configPaths 中添加 ts 文件路径。

我遇到的其他问题是 mikro-orm.config.ts 中的模式属性中的正则表达式是错误的,因为拼写错误。

于 2021-07-10T13:09:21.517 回答
0

如果任何建议的步骤都没有为您解决问题,只需...

退出 yarn watch 和 yarn dev 从命令行运行这个命令

npx mikro-orm migration:up

现在重新启动手表和开发,你应该很好。

来自https://mikro-orm.io/docs/migrations/#migration-class

于 2021-09-13T23:28:12.747 回答
0

我也经历过这个。就像Fares47 说的那样,这可能是因为我在./mikro-orm.config.ts.

我的解决方案是简单地执行./src/migrations/Migration<NUMBERS>.ts在 postgresql 终端的文件中生成的 sql 命令。这是我在数据库中执行的命令,

create table "post" ("id" serial primary key, "created_at" timestamptz(0) not null, "updated_at" timestamptz(0) not null, "title" text not null);

就像他们在文档中建议的那样,

一种安全的方法是在开发服务器上生成 SQL 并将其保存到在生产服务器上手动执行的 SQL 迁移文件中。

于 2022-02-06T09:01:33.703 回答