Sharing user_id value between two MySql table(在两个MySQL表之间共享user_id值)
问题描述
我正在使用下面的中间件AuthController.js。中间件是CRUD应用程序的一部分。我创建了exports.create
,当被请求时,它将从CRUD表单收集名字和姓氏。收集MySQLINSERT
查询后,将在MySQLuser
表上插入数据,该表运行正常。
我无法实现并且需要帮助的是,除了名字和姓氏信息,我还想插入变量{ user_id: decoded.id }
,decoded.id
是一个从另一个名为login
的MySQL表中获取user_id
值的变量。
当我请求export.create
时,终端显示以下错误:
(node:18780) UnhandledPromiseRejectionWarning: TypeError: argument callback must be a function when provided
login
表中user_id
列下的值传输到user
表中的user_id
列。感谢您的帮助。
exports.create = async (req, res, next) => {
if (req.cookies.jwt) {
try {
//1)verify the token
var decoded = await promisify(jwt.verify)(req.cookies.jwt,
process.env.JWT_SECRET
);
// console.log(decoded);
const { first_name, last_name } = req.body;
connection.query('INSERT INTO user SET first_name = ?,last_name = ?', { user_id: decoded.id }, [first_name, last_name,], (err, rows) => {
if (!err) {
res.render('add-crew', { alert: 'Crew member added succesfully!' });
} else {
console.log(err);
}
console.log('The data from user table:
', rows);
});
} catch (error) {
console.log(error);
return next();
}
}
};
推荐答案
connection.query
函数接受两到三个参数:SQL语句、(值)和回调。在这里,该函数接受四个参数,因此它认为[first_name, last_name,]
是回调。
您可以做的是:
...
connection.query('INSERT INTO user SET user_id = ?, first_name = ?,last_name = ?', [decoded.id, first_name, last_name,], (err, rows) => {
if (!err) {
res.render('add-crew', { alert: 'Crew member added succesfully!' });
} else {
console.log(err);
}
console.log('The data from user table:
', rows);
});
...
我希望这就是您要找的。
编辑您还可以:
...
connection.query('INSERT INTO user SET ?', {user_id: decoded.id, first_name: first_name, last_name: last_name}, (err, rows) => {
if (!err) {
res.render('add-crew', { alert: 'Crew member added succesfully!' });
} else {
console.log(err);
}
console.log('The data from user table:
', rows);
});
...
这篇关于在两个MySQL表之间共享user_id值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在两个MySQL表之间共享user_id值
基础教程推荐
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01
- SQL Server 2016更改对象所有者 2022-01-01
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01