SPARQL查询语句整理
本文大多内容来自Joshua Taylor的回答
https://stackoverflow.com/users/1281433/joshua-taylor
查询子类或等价关系
https://stackoverflow.com/questions/21092246/sparql-query-subclass-or-equivalentto/21093154#21093154
even though owl:equivalentClass is a symmetric property (i.e., from a owl:equivalentClass b we can infer b owl:equivalentClass a), the triple might be present in only one direction in the data
在数据里面等价关系是单向表示的,因此查询等价类的语句为
?myClass (owl:equivalentClass|^owl:equivalentClass)* :MyClass
查询等价属性的语句为
?p (owl:equivalentProperty|^ owl:equivalentProperty)* :order_no
查询<http://class/加工过程> class的property
SELECT ?subclass
WHERE {
?subclass rdfs:domain <http://class/加工过程>.#加工过程类的所有属性
}

查询<http://class/加工过程>的所有属性的所有数据(s p o)
SELECT ?s ?subclass ?o
WHERE {
?subclass rdfs:domain <http://class/加工过程>.#加工过程类的所有属性
?s ?subclass ?o#返回属性关联的所有数据
}
LIMIT 100

查询所有实例及其对应类型
SELECT ?instance ?s WHERE {
?instance rdf:type ?s. #找出实例的类型
}

查询值为1600KN20173的所有数据
SELECT ?instance ?p WHERE {
?instance ?p “1600KN20173”. #找出属性值为V101208的所有实例
}

如何获取实例对应本体
本体之间存在关系 Human ----(hasPizza)---> Pizzas
为本体添加实例 Human:Jim ----(hasPizza)---> Pizzas:cheesePizza
执行语句:
select ?x ?y where {
?x hasPizza ?y
}
返回?x=Jim 和 ?y=cheesePizza
如何得到实例对应本体?
用turtle表示rdf
@prefix : <http://example.org/pizzas#> .
@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .
@prefix pizzas: <http://example.org/pizzas#> .
@prefix owl: <http://www.w3.org/2002/07/owl#> .
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .
@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> . pizzas:Jim
a pizzas:Human , owl:NamedIndividual ;
pizzas:hasPizza pizzas:CheesePizza . pizzas:hasPizza
a owl:ObjectProperty ;
rdfs:domain pizzas:Human ;
rdfs:range pizzas:Pizza . pizzas:Human
a owl:Class . pizzas:Pizza
a owl:Class . <http://example.org/pizzas>
a owl:Ontology . pizzas:CheesePizza
a pizzas:Pizza , owl:NamedIndividual .
可以看到在模型定义中,
pizzas:hasPizza
a owl:ObjectProperty ;
rdfs:domain pizzas:Human ;
rdfs:range pizzas:Pizza .
因此可以利用属性hasPizza的rdfs:domain和rdfs:range两个关系来获得
查询语句为:
prefix : <http://example.org/pizzas#>
prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> select ?domain ?range where {
:hasPizza rdfs:domain ?domain ;
rdfs:range ?range .
}
返回:
-------------------
| domain | range |
===================
| :Human | :Pizza |
-------------------
2.利用rdf:type获取
SELECT DISTINCT ?s WHERE {
?instance rdf:type ?s. #找出所有三元组的类型
}

返回了本体和实例数据的类型,混在一起了,因为本体和数据都是用三元组表示的
所以限定到具体数据,返回类型
SELECT DISTINCT ?s WHERE {
?instance ?p "三月".
?instance rdf:type ?s. #找出实例的类型
}
实例的rdf:
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:j.0="http://class/"
xmlns:j.1="http://dataproperty/"
xmlns:owl="http://www.w3.org/2002/07/owl#"
xmlns:j.2="http://objectproperty/"
xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
xmlns:xsd="http://www.w3.org/2001/XMLSchema#">
<j.0:维保 rdf:about="http://individual/维保/1600KN20173">
<j.1:保养人>empty</j.1:保养人>
<j.1:实际保养日期>empty</j.1:实际保养日期>
<j.1:所需工时_人数_时间>2*0.1</j.1:所需工时_人数_时间>
<j.1:计划保养时间>3月5日——3月11日</j.1:计划保养时间>
<j.1:计划保养周>第10周</j.1:计划保养周>
<j.1:设备保养级别>1级</j.1:设备保养级别>
<j.1:月份>三月</j.1:月份>
<j.1:维保计划编号>1600KN20173</j.1:维保计划编号>
</j.0:维保>
查询结果:

上述查询语句是对整个数据库进行查询,所以查询了所有路径下的数据:
"http://class/"
"http://dataproperty/"
"http://objectproperty/"
等等
可以指定PREFIX : <http://class/> 减小查询范围
比如下面语句
就指定了在‘:’的范围中查找等价属性
PREFIX : <http://www.siemens.com/semantic_web#>
PREFIX owl: <http://www.w3.org/2002/07/owl#>
SELECT ?property WHERE {
? property (owl:equivalentProperty|^owl:equivalentProperty)* :order_id.
}
SPARQL查询语句整理的更多相关文章
- sql查询语句整理
首先这是我以下语句查询的一个表结构 t_user插入例如以下数据 t_depart中插入例如以下数据 t_role插入例如以下数据 好,建好表后,我们開始数据库查询语句 简单的查询语句 1. 查看表结 ...
- pg_sql常用查询语句整理
#pg_sql之增删改查 #修改: inset into table_name (id, name, age, address ) select replace(old_id,old_id,new_i ...
- MYSQL 数据库高频查询语句整理
一查询数值型数据: SELECT * FROM tb_name WHERE sum > 100; 查询谓词:>,=,<,<>,!=,!>,!<,=>,= ...
- sparql 查询语句快速入门
介绍 RDF is a directed, labeled graph data format for representing information in the Web. RDF is ofte ...
- HUE-hive常用查询语句整理
通过hue进行数据导入: ,create table demo_id(`id` string) row format serde 'org.apache.hadoop.hive.serde2.Open ...
- Jena搭建SPARQL查询RDF数据
1 Jena搭建SPARQL查询RDF数据 1.1 Jena概要 · SPARQL是W3C的RDF数据工作组设计的一种查询语言和协议,用于RDF数据的查询.经过类似于JDK安装时候的配置,可以在命令行 ...
- MySQL 笔记整理(1) --基础架构,一条SQL查询语句如何执行
最近在学习林晓斌(丁奇)老师的<MySQL实战45讲>,受益匪浅,做一些笔记整理一下,帮助学习.如果有小伙伴感兴趣的话推荐原版课程,很不错. 1) --基础架构,一条SQL查询语句如何执行 ...
- MySQL 笔记整理(2) --日志系统,一条SQL查询语句如何执行
笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> 2) --日志系统,一条SQL查询语句如何执行 MySQL可以恢复到半个月内任意一秒的状态,它的实现和日志系统有关.上一篇中记录了一 ...
- SQL逻辑查询语句执行顺序 需要重新整理
一.SQL语句定义顺序 1 2 3 4 5 6 7 8 9 10 SELECT DISTINCT <select_list> FROM <left_table> <joi ...
随机推荐
- LintCode上的一道算法面试题: 数字的统计
说到数字的统计,小时候的数学课大家都应该有学过,但数字太多太复杂的,手动肯定耗时间不说还很容易出错.所以今天分享一下如何用程序来完成. Have you met this question in a ...
- 使用EasyUI查询与删除
下面我们创建一个使用EasyUI布局的asp.net网站查询与删除数据(连接数据库) 新建网站-新建数据库(一个表,主要作用是了解一下easyUI的使用) 打开EasyUI帮助文档,自行渲染 使用da ...
- Djang简介
一:MVC简介 MVC的全拼为Model-View-Controller,最早由TrygveReenskaug在1978年提出,是施乐帕罗奥多研究中心(Xerox PARC)在20世纪80年代为程序语 ...
- Linux 下升级Android Studio失败
在Linux下进行升级的时候,会弹出一个窗口,有一个表格,从表中发现在进行某些更新某些包是没有权限,解决方法很简单,将Android Studio安装文件夹改成当前Linux登陆用户即可. 1.找到A ...
- PHP 提取数组中奇数或偶数的元素array_filter
//提取奇数 $filter = array_filter($ql,function($var){ return($var & 1); },ARRAY_FILTER_USE_KEY); pri ...
- WPF DevExpress ChartControl使用之PieChart
饼状图要比XYDiagram要简单一点,大体上也是那些东西,没有了X.Y坐标轴,也就没有了第二坐标,要简单一点.PieChartControl.xaml <UserControl x:Class ...
- socket、tcp、udp、http 的认识
一.先来一个讲TCP.UDP和HTTP关系的 1.TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层. 在网络层有IP协议.ICMP协议.ARP协议.RARP协议和BOOTP协议. 在传输 ...
- luogu SP8093 后缀自动机+树状数组+dfs序
这题解法很多,简单说几个: 1. 线段树合并,时间复杂度是 $O(nlog^2n)$ 的. 2. 暴力跳 $fail,$ 时间复杂度 $O(n\sqrt n),$ 比较暴力. 3. 建立后缀树后在 $ ...
- boost 函数与回调
result_of 含义:result_of可以帮助程序员确定一个调用表达式的返回类型,主要用于泛型编程和其他boost库组件,它已经被纳入TR1 头文件:<boost/utility/resu ...
- 终于结束的起点——Adios
准退役了一年,终于还是要结束了,整个高中的OI生涯就这么过去了. 今年的CSP-S又一次提醒我,我真的只是个蒟蒻,学了两年多还是这么个样.不过,这段OI生涯或许确实给我带来了许多. 一切的起点 17年 ...