亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

將字符串變量傳遞給 TypeOrmModuleOptions 中的“type”

將字符串變量傳遞給 TypeOrmModuleOptions 中的“type”

牛魔王的故事 2021-11-04 17:45:51
我想使用 TypeORM 為我的 NestJs 應用程序設置數據庫連接。我有一個配置文件,它從讀取所有值.env文件import { DotenvConfigOutput, config } from 'dotenv';const envFound: DotenvConfigOutput = config();if (!envFound) {  throw new Error('.env file was not found.');}process.env.NODE_ENV = process.env.NODE_ENV || 'development';export const DATABASE_TYPE: string = process.env.DATABASE_TYPE || 'postgres';export const DATABASE_USERNAME: string = process.env.DATABASE_USERNAME || 'admin';export const DATABASE_PASSWORD: string = process.env.DATABASE_PASSWORD || 'myPW';export const DATABASE_HOST: string = process.env.DATABASE_HOST || 'localhost';export const DATABASE_PORT: number = Number(process.env.DATABASE_PORT) || 5432;export const DATABASE_NAME: string = process.env.DATABASE_NAME || 'myDB';export const DATABASE_SYNCHRONIZE: boolean = Boolean(process.env.DATABASE_SYNCHRONIZE) || true;我正在 app.module 中設置連接,所以在應用程序啟動時。import {  DATABASE_TYPE,  DATABASE_HOST,  DATABASE_PORT,  DATABASE_USERNAME,  DATABASE_PASSWORD,  DATABASE_NAME,  DATABASE_SYNCHRONIZE,} from './config';@Module({  imports: [    TypeOrmModule.forRoot({      type: DATABASE_TYPE,      host: DATABASE_HOST,      port: DATABASE_PORT,      username: DATABASE_USERNAME,      password: DATABASE_PASSWORD,      database: DATABASE_NAME,      entities: [],      synchronize: DATABASE_SYNCHRONIZE,    }),  ],  controllers: [],  providers: [],})export class AppModule {}不幸的是我在type現場遇到了這個錯誤類型 'string' 不能分配給類型 '"mysql" | "mariadb" | "postgres" | "蟑螂數據庫" | "sqlite" | "mssql" | "神諭" | "科爾多瓦" | “原生腳本” | “反應原生” | "sqljs" | "mongodb" | “極光數據API” | "expo"'.ts(2322) MysqlConnectionOptions.d.ts(12, 14): 預期類型來自屬性'type',它在'TypeOrmModuleOptions'類型上聲明我不想傳遞硬編碼字符串,'postgres'因為我希望它保持動態。我更喜歡 Postgres,但有些客戶使用 oracle 數據庫,我也必須支持 MSSQL。我該如何解決該配置問題?
查看完整描述

2 回答

?
FFIVE

TA貢獻1797條經驗 獲得超6個贊

將您的數據庫類型轉換為字符串,如下所示:

   export const DATABASE_TYPE: any = String(process.env.DATABASE_TYPE) || 'postgres';


查看完整回答
反對 回復 2021-11-04
?
慕村225694

TA貢獻1880條經驗 獲得超4個贊

這對我有用:


TypeOrmModule.forRoot({

  type: "sqlite" as any,

  host: "localhost",

  database: "./database/sqlite"

})

我花了整個周末試圖找出這個問題,但被難住了。


有人有更好的解決方案或解釋嗎?


查看完整回答
反對 回復 2021-11-04
  • 2 回答
  • 0 關注
  • 345 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號