vvA*_*Ave 13 javascript node.js typescript koa typeorm
按照官方文档,我创建了小型 koa/typeorm/postgres 应用程序。当我使用createConnection
配置,在同一个文件中导入实体时,应用程序工作正常,但 typeorm cli 找不到配置文件,所以我尝试将配置移动到“ormconfig.json”。现在我收到这个错误:
SyntaxError: Cannot use import statement outside a module
看起来 typeorm 无法使用 es6 功能。
我的ormconfig.json
:
{
"type": "postgres",
"host": "localhost",
"port": 5432,
"username": ****,
"password": ****,
"database": ****,
"synchronize": true,
"entities": ["src/entity/**/*.ts"],
"migrations": ["src/migration/**/*.ts"],
"subscribers": ["src/subscriber/**/*.ts"],
"cli": {
"entitiesDir": "src/entity",
"migrationsDir": "src/migration",
"subscribersDir": "src/subscriber"
}
}
Run Code Online (Sandbox Code Playgroud)
我的tsconfig.json
:
{
"compilerOptions": {
"lib": ["es5", "es6"],
"target": "es6",
"module": "commonjs",
"moduleResolution": "node",
"outDir": "./dist",
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
},
"exclude": ["node_modules"]
}
Run Code Online (Sandbox Code Playgroud)
有错误的文件:
import {
BaseEntity,
Column,
Entity,
PrimaryGeneratedColumn,
CreateDateColumn,
ManyToOne
} from 'typeorm';
import { IsIn, IsPositive, IsNotEmpty } from 'class-validator';
import { LOAN_TYPE } from '../consts';
import { User } from './user';
@Entity('loans')
export class Loan extends BaseEntity {
@PrimaryGeneratedColumn()
public id: number;
@CreateDateColumn({ type: 'timestamp' })
public createdAt: Date;
@Column()
@IsNotEmpty()
@IsPositive()
public amount: number;
@Column({ type: 'enum', enum: LOAN_TYPE })
@IsNotEmpty()
@IsIn(Object.values(LOAN_TYPE))
public type: LOAN_TYPE;
@Column({ default: false })
public approvalStatus: boolean;
@ManyToOne(type => User, user => user.loans)
@IsNotEmpty()
public user: User;
}
export default Loan;
Run Code Online (Sandbox Code Playgroud)
Rob*_*bfz 12
尝试运行 CLI 或运行应用程序时是否收到错误消息?
您可能需要更改"entities"
的条目ormconfig.json
来["dist/entity/**/*.js"]
或"entitiesDir"
来"dist/entity"
。
归档时间: |
|
查看次数: |
7992 次 |
最近记录: |