Error: Model not initialized: "Model" needs to be added t o a Sequelize instance before "call" can be called. (Sequelize-typescript)
Asked Answered
F

2

17

Author.ts

import {Table, Model, Column, DataType} from 'sequelize-typescript'

@Table
export class Author extends Model<Author> {

constructor(){
    super();
}

@Column(DataType.STRING)
fname: string

@Column(DataType.STRING)
lname: string

}

App.ts

import {Sequelize} from 'sequelize-typescript';
import { customer } from './model/customer';
import { Author } from './model/Author';

export  class SQLRepo {

     repo:Sequelize = null;

     constructor(){
         this.connectDb();
     }

  connectDb(): any {

    this.repo =  new Sequelize({
        database: 'postgres',
        dialect: 'postgres',
        host: 'localhost',
        username: 'postgres',
        password: 'xxxxx',
        storage: 
               'D:/Sequalize/assosiation/database.sqlite',
        modelPaths: [__dirname + '/models'],
        define: {
            underscored: false,
            freezeTableName: false,
            timestamps: false
        }
     });

     this.repo.addModels([Author])

     this.repo.
     authenticate().
     then(function(){
         console.log("database connected ...")

         new Author({fname: 'karim' , lname: 'mirazul'}).save();

     }).
     catch(function(error){
         console.log("Database catch block : "+ error)
     })
   }
}
new SQLRepo();

create SQLRepo call object so by this I can connect to database successfully but It shows error after database is connected .. When it try to insert data into Author

it give me this output :

Executing (default): SELECT 1+1 AS result database connected ... Database catch block :

Error: Model not initialized: "Model" needs to be added to
 a Sequelize instance before "call" can be called.
Fieldfare answered 5/1, 2018 at 2:40 Comment(1)
try to drop modelPaths from the config option you pass to new Sequelize. I think it's redundant and may cause the problem.Pusillanimous
P
10

Remove constructor call from model

import {Table, Model, Column, DataType} from 'sequelize-typescript'

@Table
export class Author extends Model<Author> {

  // constructor(){
  //     super();
  // }

  @Column(DataType.STRING)
  fname: string

  @Column(DataType.STRING)
  lname: string

}

You cannot use constructor as it's used by sequelize for internal things

source

Photoelectron answered 2/12, 2019 at 22:45 Comment(0)
I
-4

Changing target: "es5" to target: "es6" helped me solve this issue. It is not documented but it is present in the example provided.

Irremissible answered 5/2, 2018 at 8:38 Comment(1)
Tries this solution and it remains the same issue.Manthei

© 2022 - 2025 — McMap. All rights reserved.