[英]How to you get the last inserted ID with a raw query using Sequelize?
在sequelize.js中嘗試以下原始MySQL插入時:
mysql_sequelize.query( 'INSERT IGNORE INTO steamer(steamer_id, prov_id, name, avatar) VALUES(UNHEX(REPLACE(UUID(),\'-\',\'\')), \'' + prov_id + '\', \'' + steamer_name + '\', \'' + steamer_avatar + '\')')
.then(function (data) {
console.log('inserted STEAMER data---> ',data); // no useful info
});
);
生成的控制台日志如下所示:
inserted STEAMER data---> [ OkPacket {
fieldCount: 0,
affectedRows: 1,
insertId: 0,
serverStatus: 2,
warningCount: 1,
message: '',
protocol41: true,
changedRows: 0 },
OkPacket {
fieldCount: 0,
affectedRows: 1,
insertId: 0,
serverStatus: 2,
warningCount: 1,
message: '',
protocol41: true,
changedRows: 0 } ]
我需要做什么才能獲得以下數據的ID? 甚至最后插入的ID?
您可以通過傳遞{ type: sequelize.QueryTypes.INSERT }
作為選項參數來實現此目的。 這將使sequelize返回插入它。
簡單的查詢示例:
sequelize.query(
"INSERT INTO clients (name) values ('myClient')",
{ type: sequelize.QueryTypes.INSERT }
).then(function (clientInsertId) {
console.log(clientInsertId);
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.