To add multiple columns in sequelize
Step 1: generate empty migration
sequelize migration:generate --name custom_name_describing_your_migration
Step 2: add columns to the empty migration
Use a transaction as per the docs https://sequelize.org/master/manual/migrations.html#migration-skeleton:
module.exports = {
up: (queryInterface, Sequelize) => {
return queryInterface.sequelize.transaction((t) => {
return Promise.all([
queryInterface.addColumn('table_name', 'field_one_name', {
type: Sequelize.STRING
}, { transaction: t }),
queryInterface.addColumn('table_name', 'field_two_name', {
type: Sequelize.STRING,
}, { transaction: t })
])
})
},
down: (queryInterface, Sequelize) => {
return queryInterface.sequelize.transaction((t) => {
return Promise.all([
queryInterface.removeColumn('table_name', 'field_one_name', { transaction: t }),
queryInterface.removeColumn('table_name', 'field_two_name', { transaction: t })
])
})
}
};
Step 3: run the migration
sequelize db:migrate