论文注解《Query Languages for Graph Databases》graph数据库查询语法(II)

本文主要是介绍论文注解《Query Languages for Graph Databases》graph数据库查询语法(II),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

联合正则路径查询

  • 通过结合 CQ RPQ 得到 CRPQ ,形式如 (2)

比较并返回路径

  • 在某些场景下(例如找出web上联通的数据),需要指定路径间的关系同时得到实际的路径作为查询结果
  • ECRPQ 提供以上两种特性, ECRPQ 在两个层面上扩展了 CRPQ
    • 允许查询的头部存在自由路径变量
    • 允许校验查询体中路径间的关系而不是简单的令路径和正则语言相匹配
  • 我们首先基于 Σ 定义正则关系的规范。设为一个独立于 Σ 的符号,利用扩展 Σ 得到Σ
  • x¯=(s1,s2,...sn) 为一个基于 Σ 的字符串的n元组。构造一个基于 (Σ)n 字符串 [s¯] ,其长度是 sj 的最大值,且第 i 个符号是一个元组(c1,...,cn)(当 sk 的长度至少是 i 时,每个ck等于 sk 的第 i 个符号,否则等于)。也就是说我们用 填补短字符串,从而把 n 个字符串视作一个字符串。对于任何Σ中的 n 元关系S,当基于 (Σ)n 的字符串集合 [s¯]|s¯S 能被基于 (Σ)n 的正则自动机接受或者能用基于 (Σ)n 正则表达式表示,则被认为是正则的。我们也应当利用相同的字母来表示基于 (Σ)n 的正则表达式和基于 Σ 的关系
  • 除了 CRPQ 中的节点变量,我们还确定了一个可数路径变量集合(用 π,ω,χ 来表示)。一条基于 Σ 的扩展联合正则路径请求ECRPQ的表达式为:
    ans(z¯,χ¯)1im(xi,πi,yi),1jtRj(ω¯j)

    1. m>0,t0
    2. 每个 Rj 是一个定义了正则关系的正则表达式
    3. x¯=(x1,...,xm) y¯=(y1,...,ym) 都是节点变量元组
    4. π¯=(π1,...,πm) 是路径变量元组
    5. {w¯1,...,w¯t} 是不同的路径变量元组,例如 w¯j 是一个 π¯ 中变量的元组,变量数目等于 Rj
    6. z¯ 是一个 x¯,y¯ 中节点变量的元组
    7. χ¯ 是一个 π¯ 中路径变量的元组
  • ECRPQ 的语义是 CRPQ 的延伸。对于一个 ECRPQ 的查询,从节点变量到节点的映射关系为 σ ,从路径变量到路径的映射关系为μ,当满足以下两个条件时,则可认为 (G,σ,μ)|=Q
    • μ(πi) G 中的一条从σ(xi) σ(yi) 的路径, 1im
    • 对于每个 w¯j=(πj1,...,πjk) ,由 μ(πj1),...μ(πjk) 中标签组成的字符串元组属于关系 Rj
  • 查询结果可定义为:
    Q(G)={(σ(z¯),μ(χ¯))|(G,σ,μ)|=Q}
  • 举例说明:
    • RDF 的查询语句中,路径可以被基于特定的语义关联比较。边相当于 RDF 属性路径相当于属性序列。定义属性 a b的子属性 ab 。两个属性序列 u v被称作 ρisomorphic (路径同构)当且仅当 u=u1,...,un v=v1,...,vn uivi viui 1in 。节点 x y被称作 ρisoAssociated (路径关联)当且仅当 x y是两条同构路径属性序列的起点。
    • 找出路径关联的节点无法使用 CRPQ 表示,因为这需要保证两条路径长度相同。然而,路径同构的属性对能用基于表达式 (a,bσ:(abba)(a,b)) 的正则关系 R 来表示。一个ECRPQ返回路径关联的点对 x y可以被写成以下形式:
      ans(x,y)(x,π1,z1),(y,π2,z2),R(π1,π2)
      ECRPQ 中的路径变量也可以被用来返回找出的实际路径。例如我们需要找出 RDF 资源 r s间的每条路径,且路径包含资源 e ,可以用以下形式表示:
      ans(π1,π2)(r,π1,e),(e,π2,s)
      π1 π2 为实际路径
    • 包含回溯引用的正则表达式 (REBR) ,正如 egrep Perl 中所提供的。举个例子, (r)%X r 是正则表达式,X是变量(绑定字符串 wL(r) X )。然后用表达式中的X去匹配 w ECRPQ不能表示所有的 REBR ,但另一方面, ECRPQ 能匹配模式,例如 anbncn
      ans(x,y)(x,π1,z1),(z1,π2,z2),(z2,π3,y),a(π1),b(π2),c(π3),el(π1,π2),el(π2,π3)

      el(π,π) 是的简写 (a,bσ(a,b))(π,π)

这篇关于论文注解《Query Languages for Graph Databases》graph数据库查询语法(II)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/623850

相关文章

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

Idea实现接口的方法上无法添加@Override注解的解决方案

《Idea实现接口的方法上无法添加@Override注解的解决方案》文章介绍了在IDEA中实现接口方法时无法添加@Override注解的问题及其解决方法,主要步骤包括更改项目结构中的Languagel... 目录Idea实现接China编程口的方法上无法添加@javascriptOverride注解错误原因解决方

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多