- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建两个函数,一个从 SQL 数据库检索对象,另一个将对象保存到同一个 SQL 数据库。我使用 node.js
和 mysql
来执行此操作。我有两个函数,fetchEmployee
和 Employee.save
,分别获取和保存员工。然而,当我调用 fetchEmployee
并且回调包含 Employee.save
时,我收到错误 Cannot enqueue Handshake after already enqueue Handshake.
即使更奇怪的是,Employee.save
似乎在抛出错误之前运行。
编辑:employee.save
出现运行是异步的症状,因为console.log("Saved!")
被调用在回调函数传递给SQL.parse
之前,这意味着错误出现在parse
期间。此外,如果在 parse 中,在 con.connect
之后添加 console.log("connection Created");
,并且 console.log("Made it out.");
添加在con.connect
末尾,调用Employee.save
时,控制台输出> "connection Created"
,然后抛出错误,意味着保存查询永远不会完成,但在 con.connect
Employee类由以下定义
function Employee(obj) {
/** Defines the Employee class
* @arg obj.id : an integer; the employee's id
* @arg obj.name : A string; the employee's name
* @arg obj.position : A string; the employee's positions split by commas
*/
this.id = obj.id;
this.name = obj.name;
this.position = obj.position;
this.save = function() {
SQL.parse({
sql : `UPDATE EMPLOYEES
SET id=?, name=?, position=?
WHERE id=?`,
replace_ : [this.id, this.name, this.position, this.id],
result : false
});
console.log("Saved!");
}
}
注意 console.log("Saved!");
,因为稍后会出现
fetchEmployee
由以下函数定义:
function fetchEmployee(id, callback) {
/** Fetch an employee from the employee table
* @arg id : An integer; the id of the employee to fetch
* @arg callback : A callback function to pass the employee to
*/
SQL.parse({ // Perform the parse, define the sql, replace, and result
sql : "SELECT * FROM employees WHERE id=?",
replace_ : [id],
result : true
},
function(err, data) {
if(err) { // Pass an error if there's an error
callback(err, null);
throw err;
}
// Pass the employee to the callback as an employee object if there's no errors
callback(null, new Employee({ // data is passed as a list from the sql table, so take only the object we need through [0]
id : data[0].id,
name : data[0].name,
position : data[0].position
})
);
});
}
最后,SQL.parse 在此文件中定义:
var mySQL = require("mysql");
var con = mySQL.createConnection({ //Create connection
host : "localhost",
database : "testdb1",
user : "root",
password : "***************"
});
function parse(obj, callback) {
/** Parses an sql query.
* @arg callback : A callback function, will be passed the data
* @arg obj.sql : an sql query
* @arg obj.replace_ : A list of replacements for ?s in sql
* @arg obj.result : a boolean indicating whether a result should be returned
*/
//Assign meaningfull values
obj.replace_ = obj.replace_ || [];
callback = callback || function() {};
con.connect(function(err) {
if(err) throw err;
//Connect and pass the sql command to the server
con.query(obj.sql, obj.replace_, function(err, data) {
if(err) { //Pass the err to the callback if there is an err
callback(err, null);
throw err;
}
else if(obj.result) { // Pass the data to the callback if result is true
callback(null, data)
}
});
});
}
module.exports = {
parse : parse
};
当我调用这段代码时
fetchEmployee(985, function(err, data) {
if(err) throw err;
console.log(data);
data.save();
});
控制台输出
Employee {
id: 985,
name: 'Skidd',
position: 'Dishwasher, Busser',
save: [Function] }
Saved!
Error: Cannot enqueue Handshake after already enqueuing a Handshake. [...]
在我看来,它正确运行fetchEmployee
,因为数据与员工的数据一起正确记录到控制台。然后它会记录 Saved!
,似乎表明 Employee.save
运行正确,然后在完成所有代码后,抛出错误。我一生都无法弄清楚为什么会发生这种情况,无论是在这里还是在谷歌上或通过测试。
我尝试将 con.end
添加到 sql.js
中 parse
的末尾,这会将错误更改为 调用退出后无法将握手入队
最佳答案
我能够通过放置来解决这个问题
var con = mySQL.createConnection({ //Create connection
host : "localhost",
database : "testdb1",
user : "root",
password : "***************"
});
在 parse
函数内部,尽管我不是 100% 确定为什么会这样。
关于javascript - Node .js + mysql : "Cannot enqueue Handshake after already enqueuing a Handshake.",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52957041/
我正在从不同来源获取新闻提要并添加到数据库,但我遇到异常 Error: Cannot enqueue Handshake after already enqueuing a Handshake. at
嘿,大家好,我只是想制作一个简单的表单,将数据发送到 mySQL 数据库。我的问题是提交后我无法再提交另一份。它只允许我提交表单一次,然后在第二次提交后,我收到此错误“错误:在已经排队握手后无法排队握
我每 5 秒查询一个表并向用户显示。我使用的是mysql 8。应用程序是nodejs。 var con = mysql.createConnection({ host: "localhost",
我正在尝试创建两个函数,一个从 SQL 数据库检索对象,另一个将对象保存到同一个 SQL 数据库。我使用 node.js 和 mysql 来执行此操作。我有两个函数,fetchEmployee 和 E
我需要一个具有固定容量但始终允许线程将项目添加到开头的 Java 列表。如果它已满,它应该从末尾删除一个项目以腾出空间。没有其他进程会删除项目,但其他进程会希望迭代这些项目。 JDK 中有什么东西可以
我在 tensorflow 中构建了一个卷积神经网络。它经过培训,现在我正在打开它并进行评估。 import main import Process import Input eval_dir = "
如果last会变成x,为什么last.next会被分配给x?我不明白将 x 分配给 last.next 有何影响。这是队列的完整上下文:http://introcs.cs.princeton.edu/
我在创建具有双因素身份验证的应用程序时遇到了一些麻烦。我决定使用 twilio 作为我的短信网关,并决定遵循他们的教程。然而,尽管已经导入了我需要的内容,但我遇到了无法解决排队问题。 import a
注册样式表然后将其入队与直接入队有何不同? 我在这里注册然后排队。 function calling_script(){ wp_register_style('bootstrap',
假设我有一个模块,其中有一个队列。 对于其他实体入队,它们必须通过一个函数: public sub InsertIntoQueue(Obj) MyQueue.Enqueue(Obj) end
我有一个包含 6 个库的列表,我想加载到我的 WordPress 插件/主题中。目前它们都像这样添加到主题的标题中。 我正在构建一个插件,它有自己的脚本,依赖于这些库。我想运行我提出的这个解决方案,
只需要一些关于 WP en 队列的信息,我已经在各个网站上学习了一些教程,因为我是一个非常基础的网页设计师,我主要使用 HTML CSS 至少这是我最了解的。 我无法最好地解释我哪里出了问题,但我可以
有没有办法在一定时间后重定向队列中的调用? 我在 Twiml 中知道 您可以设置超时。 有没有办法在 中做到这一点?甚至 作为它的一部分 waitURL 现在我正在做这样的事情:
目前正在准备考试,无法弄清楚示例代码中 queue[rear*] = new_node 背后的原因。 你不是把 new_node 的地址而不是值放进去吗? 还有,这个队列是不是Node**队列,因为它
我是编程新手。尝试编写一个函数来接收列表的头部 + 要插入的数据 - 并传回列表的新头部。我已经通过将元素添加到列表的头部来完成很多工作,但出于某种原因,我无法理解这个细微的差别。 #include
我是队列实现的新手,需要一些帮助来练习。 假设我正在使用 enqueue 对 4 个人进行排队,并且我想向输出添加一个函数,以显示 1 到 10 之间的随机数“x”4 次,并符合以下条件: 如果“x”
首先,我将解释一个简短的场景; 当来自某些设备的信号触发时,一个类型为 Alarm 的对象被添加到队列中。每隔一段时间检查队列,并针对队列中的每个警报触发一个方法。 但是,我遇到的问题是,如果在遍历队
有人可以解释一下主要区别吗?我对任何语言的编程中的这些功能都没有清楚的了解。 最佳答案 C 和 C++ 等编程语言中的一些基本数据结构是堆栈和队列。 堆栈数据结构遵循“先进后出”策略 (FILO),其
private Queue _queueObject = new Queue(); private static Queue _queueItem = new Queue(); private sta
我在CircularArrayQueue类中遇到了enqueue()方法: public void enqueue (T element) { if (size() == queue.length){
我是一名优秀的程序员,十分优秀!