How do plurals work in Sequelize?

后端 未结 1 1905
眼角桃花
眼角桃花 2021-01-07 10:56

While using Sequelize and reading the Sequelize docs, I observed that sometimes model names are used in singular and sometimes in plural. Some methods automatically added to

相关标签:
1条回答
  • 2021-01-07 11:19

    How Sequelize computes plurals

    Under the hood, sequelize uses an awesome library called inflection to compute singular and plural forms of words, which works with virtually any english word, including irregular plurals such as "Person" -> "People", "Octopus" -> "Octopi", "Tooth" -> "Teeth". There are a few words that inflection gets wrong though, and for those cases, or cases in which you want to force your custom singular/plural words, see the next topic.


    What if I want to use a noun with an irregular plural?

    As said above, most words with irregular plurals will be pluralized correctly by inflection (including "Person"). But there are a few words that inflection gets wrong. Sequelize allows you to force the singular and plural forms you wish, usually accepting a plain object with the form { singular: "your-singular-here", plural: "your-plural-here" } in place of the name string. See the next topics for more details.


    When defining an instance

    When defining an instance, the standard way is to use the singular name, but you can also use the plural name, since sequelize will apply inflection methods on it to get the singular and plural form whenever needed:

    const Foo = sequelize.define("foo", {
        // attributes
    });
    

    If you want to force your custom singular and plural forms, use the third parameter to specify the name option:

    const Foo = sequelize.define("foo", {
        // attributes
    }, {
        name: {
            singular: "mycustomsingularstring",
            plural: "mycustompluralstring"
        }
    });
    

    When defining an alias

    When defining an alias for a hasOne or belongsTo association, you must use the singular form:

    Foo.belongsTo(Bar, { as: "person" });
    

    When defining an alias for a hasMany or belongsToMany association, you must use the plural form:

    Foo.belongsToMany(Bar, { through: Foo_Bar, as: "people" });
    

    Or, if you want to force your custom singular/plural strings:

    Foo.belongsToMany(Bar, {
        through: Foo_Bar,
        as: {
            singular: "mycustomsingularstring",
            plural: "mycustompluralstring"
        }
    });
    

    When defining a Many-to-many relationship

    If you have a sequelize model for the junction table itself, the best practice is to use the model itself in the through option:

    // If you have this somewhere
    const Foo_Bar = sequelize.define("foo_bar", {
        // attributes
    });
    
    // Then the best practice is to pass the model itself
    Foo.belongsToMany(Bar, { through: Foo_Bar });
    

    If you don't have a sequelize model for the junction table itself, which is not unusual (you are letting sequelize do the many-to-many magic by itself), then you must use the plural form:

    Foo.belongsToMany(Bar, { through: "foo_bars" });
    

    By the way, you might have noticed that all model definitions in my examples are lowercase, this is to follow a convention from PostgreSQL (if you have uppercase letters in your tables in PostgreSQL you might have problems), but if you're not using PostgreSQL you're probably fine to use uppercase characters in your model names.

    0 讨论(0)
提交回复
热议问题