在 Sequelize model.destroy({ truncate: true }) 不会重置主键
在 Sequelize 中,我使用了这个函数 model.destory({ truncate: true }),它会删除表中的所有数据.但问题是它不会重置表中应该设置为零的主键序列.我正在使用Mysql.有人说Mysql会自动重置主键序列,但在我的情况下没有发生.
In Sequelize, I am using this function model.destory({ truncate: true }), it delete all data in table. But the issue is that it does not reset the primary key sequence in table which should be set to Zero. I am using Mysql. Some said that Mysql automatically reset the primary key sequence, but it is not happening in my case.
这是我的代码:
db.Booking.destroy({ truncate: { cascade: false } })
.then(() => {
res.json({ status: true });
}, (err) => {
console.log('truncate: ', err);
res.json(err);
});
推荐答案
你没有使用正确的语法:
You're not using the correct syntax:
db.Booking.destroy({ truncate: { cascade: false } })
应该是:
db.Booking.destroy({ truncate : true, cascade: false })
请参阅文档.
相关文章