问题描述
也许你可以帮我解决这个问题。我正在尝试在我的 js 应用程序中编写对 Neo4J 数据库的 get 请求并将此数据发送到 ejs 页面。问题是,当我的请求一无所获(null)时,它会阻止我所有的代码并显示错误:“TypeError:无法读取 null 的属性 'identity'”。我唯一要寻找的是,当没有检索到任何数据时,不会发生任何事情而不会抛出任何错误......只继续执行其余的代码,但我不知道如何处理这个“空”。>
app.get('/page/:id',function(req,res) {
var id = req.params.id;
session
.run("OPTIONAL MATCH(a:Person)-[r]-(b) WHERE id(a)=toInteger($idParam) RETURN b",{
idParam:id
})
.then(function(result2){
var RelationArr = [];
result2.records.forEach(function(record){
RelationArr.push({
id: record._fields[0].identity.low,name: record._fields[0].properties.name,title: record._fields[0].properties.title,});
});
res.render('person',{
relation: RelationArr,});
})
.catch(function(err){
console.log(err);
});
})
解决方法
在访问 props 之前检查该值是否存在。
app.get('/page/:id',function(req,res) {
var id = req.params.id;
session
.run("OPTIONAL MATCH(a:Person)-[r]-(b) WHERE id(a)=toInteger($idParam) RETURN b",{
idParam:id
})
.then(function(result2){
var RelationArr = [];
result2.records.forEach(function(record){
if(record._fields[0]) {
RelationArr.push({
id: record._fields[0].identity.low,name: record._fields[0].properties.name,title: record._fields[0].properties.title,});
}
});
res.render('person',{
relation: RelationArr,});
})
.catch(function(err){
console.log(err);
});
})
我没有更改 javascript 代码来处理空值,而是更改了 Neo4J 查询以避免出现“空”值:
MATCH(a)-[r]-(b) WHERE id(a)=toInteger($idParam) OPTIONAL MATCH (a) WHERE id(a)=toInteger($idParam) RETURN b
谢谢@CaptEmulation,你的贡献给了我查看查询结果的提示。