联合正则路径查询

  • 通过结合 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)@H_813_3270@,...μ(π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))(π,π)

A Simple Review Of 《Query Languages for Graph Databases》II的更多相关文章

  1. HTML5数字输入仅接受整数的实现代码

    这篇文章主要介绍了HTML5数字输入仅接受整数的实现代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. ios – 如何从变量访问属性或方法?

    是否可以使用变量作为Swift中方法或属性的名称来访问方法或属性?在PHP中,您可以使用$object->{$variable}.例如编辑:这是我正在使用的实际代码:解决方法你可以做到,但不能使用“纯粹的”Swift.Swift的重点是防止这种危险的动态属性访问.你必须使用Cocoa的Key-ValueCoding功能:非常方便,它完全穿过你要穿过的字符串到属性名称的桥,但要注意:这里是龙.

  3. iOS >>块>>更改块外部的变量值

    我不是在处理一个Object并改变它,就像我的mString一样.我希望’center’属性的行为类似于myInt,因为它是直接访问的C结构,而不是指向对象的指针.我希望’backgroundColor’的行为类似于我的imstring,因为它是一个指向一个新对象的对象的指针,不是吗?

  4. ios – Xcode Bot:如何在post触发器脚本上获得.ipa路径?

    我正在使用机器人来存档iOS应用程序,我需要获取.ipa产品路径才能将其发布到我们的分发系统中.机器人设置:并使用脚本打印所有env变量,其中不包含ipa文件的路径.此外,一些变量指向不存在的目录,即:XCS_OUTPUT_DIR这里的env变量输出:除此之外,我还能够确认.ipa文件是在另一个文件夹中创建的(/IntegrationAssets//

  5. ios – 使用附加字符串本地化Info.plist变量

    我正在尝试本地化应用程序的名称,同时仍然能够根据构建配置追加字符串.所以目前它被设置为:该设置定义为:通过这种方式,我们可以为应用程序添加后缀以用于不同的beta版本.问题是,当我们尝试本地化本地化的InfoPlist.strings中的应用程序显示名称时,就像这样我们覆盖存储在Info.plist中的值,并丢失后缀字符.这有什么好办法吗?

  6. iOS – 开始iOS教程 – 变量之前的下划线?

    这是正确的还是我做错了什么?

  7. ios – 静态计算变量被多次实例化

    我有一个日期格式化程序,我试图在UITableViewCell子类中创建一个单例,所以我创建了一个这样的计算属性:问题是我不止一次看到print语句,这意味着它不止一次被创建.我已经找到了其他方法,但我很想知道这里发生了什么.有任何想法吗?解决方法您的代码段相当于只获取属性,基本上它与以下内容相同:如果你只想运行一次,你应该像定义一个惰性属性一样定义它:

  8. ios – 使用大写符号在字符串swift中获取URL的正则表达式

    我尝试在文本中获取URL.所以,在此之前,我使用了这样一个表达式:但是当用户输入带有大写符号的URL时(例如Http://Google.com,它与它不匹配)我遇到了问题.我试过了:但什么都没发生.解决方法您可以使用正则表达式中的i内联标志关闭区分大小写,有关可用正则表达式功能的详细信息,请参阅FoundationFrameworkReference.(?ismwx-ismwx)Flagsetti

  9. ios – UIApplication.delegate必须仅在主线程中使用[复制]

    我应该在主调度中的viewControllers中声明这些)变量位置声明定义了它的范围.您需要确定这些变量的范围.您可以将它们声明为项目或应用程序级别(全局),类级别或特定此功能级别.如果要在其他ViewControllers中使用这些变量,则使用公共/开放/内部访问控制将其声明为全局或类级别.

  10. ios – 无法理解Objective-C块文档

    为什么localVariable“按价值使用?”>如果我在第二个例子中将__block存储类型添加到localVariable,我错误地假设该块关闭了变量,所以它将它保留在堆中直到块被释放?解决方法Howexactlyisoneexample“accessedbyreference”whiletheotheroneisaccessedbyvariable?self是当前正在执行找到块的方法的对象.强引用只是意味着对象的保留计数增加.IfIaddthe__blockstoragetypetolocalVar

随机推荐

  1. 法国电话号码的正则表达式

    我正在尝试实施一个正则表达式,允许我检查一个号码是否是一个有效的法国电话号码.一定是这样的:要么:这是我实施的但是错了……

  2. 正则表达式 – perl分裂奇怪的行为

    PSperl是5.18.0问题是量词*允许零空间,你必须使用,这意味着1或更多.请注意,F和O之间的空间正好为零.

  3. 正则表达式 – 正则表达式大于和小于

    我想匹配以下任何一个字符:或=或=.这个似乎不起作用:[/]试试这个:它匹配可选地后跟=,或者只是=自身.

  4. 如何使用正则表达式用空格替换字符之间的短划线

    我想用正则表达式替换出现在带空格的字母之间的短划线.例如,用abcd替换ab-cd以下匹配字符–字符序列,但也替换字符[即ab-cd导致d,而不是abcd,因为我希望]我如何适应以上只能取代–部分?

  5. 正则表达式 – /bb | [^ b] {2} /它是如何工作的?

    有人可以解释一下吗?我在t-shirt上看到了这个:它似乎在说:“成为或不成为”怎么样?我好像没找到’e’?

  6. 正则表达式 – 在Scala中验证电子邮件一行

    在我的代码中添加简单的电子邮件验证,我创建了以下函数:这将传递像bob@testmymail.com这样的电子邮件和bobtestmymail.com之类的失败邮件,但是带有空格字符的邮件会漏掉,就像bob@testmymail也会返回true.我可能在这里很傻……当我测试你的正则表达式并且它正在捕捉简单的电子邮件时,我检查了你的代码并看到你正在使用findFirstIn.我相信这是你的问题.findFirstIn将跳转所有空格,直到它匹配字符串中任何位置的某个序列.我相信在你的情况下,最好使用unapp

  7. 正则表达式对小字符串的暴力

    在测试小字符串时,使用正则表达式会带来性能上的好处,还是会强制它们更快?不会通过检查给定字符串的字符是否在指定范围内比使用正则表达式更快来强制它们吗?

  8. 正则表达式 – 为什么`stoutest`不是有效的正则表达式?

    isthedelimiter,thenthematch-only-onceruleof?PATTERN?

  9. 正则表达式 – 替换..与.在R

    我怎样才能替换..我尝试过类似的东西:但它并不像我希望的那样有效.尝试添加fixed=T.

  10. 正则表达式 – 如何在字符串中的特定位置添加字符?

    我正在使用记事本,并希望使用正则表达式替换在字符串中的特定位置插入一个字符.例如,在每行的第6位插入一个逗号是什么意思?如果要在第六个字符后添加字符,请使用搜索和更换从技术上讲,这将用MatchGroup1替换每行的前6个字符,后跟逗号.

返回
顶部