如何在 sqlwrl 查询中编写 OR 操作

How to write OR operation in sqwrl query

对于 sqlwrl 查询中的 AND 操作,就像:

Symptom(fever) ^ Symptom(vomiting) ^ Disease(?y) ^ hasSymptom(?y,fever) ^ hasSymptom(?y,vomiting) -> sqwrl:select(?y)

从以上规律可知,select同时具有两种症状的疾病。 sqlwrl 查询中的 OR 操作呢?我想select有症状发烧或症状呕吐的疾病?任何帮助将不胜感激。

我想,您要搜索的内容可以用 collections 来完成。有了它们,您可以定义析取。我不确定,但也许您想要的查询如下所示:

Symptom(?fever) ^ Symptom(?vomiting) ^ Disease(?x) ^ Disease(?y) ^
hasSymptom(?x, ?fever) ^ hasSymptom(?y, ?vomiting) ˚
sqwrl:makeSet(?s1, ?x) ^ sqwrl:makeSet(?s2, ?y) ˚
sqwrl:union(?s3, ?s1, ?s2)
-> sqwrl:select(?s3)

select 有呕吐或发烧症状的疾病的正确答案。

Symptom(fever) ^ Symptom(vomiting) ^ Disease(?x) ^ Disease(?y) ^ has_symptom(?x, fever) ^ has_symptom(?y, vomiting)˚sqwrl:makeSet(?s1, ?x) ^ sqwrl:makeSet(?s2, ?y)˚sqwrl:union(?s3, ?s1, ?s2) ^ sqwrl:element(?e, ?s3) -> sqwrl:select(?e)