获取共享特殊值的最常见的配对。

huangapple go评论52阅读模式
英文:

Get the most frequent pairs that share a special value

问题

这是我第一次使用SPARQL,我正在为电影和演员创建一个本体。

  • 我有MovieActor类,并且每个电影实例都有演员。

  • Actor类有一个对象属性hasGender,用于指示演员是男性还是女性。

我需要一个查询来返回最频繁一起工作的男演员和女演员的配对。

我编写了一个查询来返回最频繁的男演员:

  1. PREFIX ontology: <https://....../>
  2. SELECT ?MaleActor ?FemaleActor (count(?Movie) as ?MoviesCount)
  3. WHERE {
  4. ?Movie ontology:hasActor ?MaleActor.
  5. ?Movie ontology:hasActor ?FemaleActor.
  6. ?MaleActor ontology:hasGender "Male".
  7. ?FemaleActor ontology:hasGender "Female".
  8. FILTER (?MaleActor != ?FemaleActor)
  9. }
  10. GROUP BY ?MaleActor ?FemaleActor
  11. ORDER BY DESC(?MoviesCount)
  12. LIMIT 1

这个查询将返回三个值:

  1. 男演员
  2. 女演员
  3. 他们一起工作的电影数量
英文:

This is my first time with SPARQL and I’m working on an ontology for movies and actors.

  • I have Movie and Actor classes, and each instance of movie has actors.

  • The Actor class has the object property hasGender which tells if an actor is Male or Female.

I need a query to return the pairs of male and female actors who worked together most frequently.

I wrote query return the most frequent Male Actor:

  1. PREFIX ontology: &lt;https://....../&gt;
  2. SELECT ?Actor (count (?Movie) as ?MoviesCount)
  3. WHERE {
  4. ?Movie ontology:hasActor ?Actor.
  5. ?Actor ontology:hasGender ?Gender
  6. filter regex (str(?Gender), &quot;Male&quot;)
  7. }
  8. Group by ?Actor
  9. Order by desc (?MoviesCount)

I wrote query return the most frequent Female Actor:

  1. PREFIX ontology: &lt;https://....../&gt;
  2. SELECT ?Actor (count (?Movie) as ?MoviesCount)
  3. WHERE {
  4. ?Movie ontology:hasActor ?Actor.
  5. ?Actor ontology:hasGender ?Gender
  6. filter regex (str(?Gender), &quot;Female&quot;)
  7. }
  8. Group by ?Actor
  9. Order by desc (?MoviesCount)

But that is not what I need.

I need only one query which should return 3 values:

  1. The Actor
  2. The Actress
  3. The Movies count which the pair worked on together

答案1

得分: 1

你可以通过将查询变量?Actor设定为特定性别(例如,?actor?actress)来合并两个查询。

  1. SELECT ?actress ?actor (COUNT(?movie) as ?movie_count)
  2. WHERE {
  3. ?movie
  4. ontology:hasActor ?actress ;
  5. ontology:hasActor ?actor .
  6. ?actress ontology:hasGender ?female .
  7. ?actor ontology:hasGender ?male .
  8. FILTER regex(str(?female), "Female") .
  9. FILTER regex(str(?male), "Male") .
  10. }
  11. GROUP BY ?actress ?actor
  12. ORDER BY DESC (?movie_count)

而不是使用FILTER,你可以直接指定性别值:

  1. # 如果它是一个对象:
  2. ?actress ontology:hasGender <你的“Female”概念的URI> .
  3. # 如果它是一个字符串:
  4. ?actress ontology:hasGender "Female" .
  5. # 如果它是一个带有语言标签的字符串:
  6. ?actress ontology:hasGender "Female"@en .
英文:

You can combine both of your queries by making the query variable ?Actor gender-specific (e.g., ?actor and ?actress).

  1. SELECT ?actress ?actor (COUNT(?movie) as ?movie_count)
  2. WHERE {
  3. ?movie
  4. ontology:hasActor ?actress ;
  5. ontology:hasActor ?actor .
  6. ?actress ontology:hasGender ?female .
  7. ?actor ontology:hasGender ?male .
  8. FILTER regex(str(?female), &quot;Female&quot;) .
  9. FILTER regex(str(?male), &quot;Male&quot;) .
  10. }
  11. GROUP BY ?actress ?actor
  12. ORDER BY DESC (?movie_count)

Instead of using a FILTER, you can directly specify the gender value:

  1. # if it’s an object:
  2. ?actress ontology:hasGender &lt;the URI of your &quot;Female&quot; concept&gt; .
  3. # if it’s a string:
  4. ?actress ontology:hasGender &quot;Female&quot; .
  5. # if it’s a language-tagged string:
  6. ?actress ontology:hasGender &quot;Female&quot;@en .

huangapple
  • 本文由 发表于 2023年4月17日 00:07:48
  • 转载请务必保留本文链接:https://go.coder-hub.com/76028869.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定