PHP 构建语义Web CRUD 操作

作者:网络 来源:佚名 更新时间:2009-01-04 12:07:28 点击:
菜鸟学堂:

创建、读、更新和删除(create/read/update/delete,crud)操作是最基本的数据库操作,但是它们也是最重要的操作。crud 操作通常是使用关系数据库系统中的结构化查询语言(structured query language,sql)完成的。随着 web 变得更加具有面向数据特性,因此需要从基于 sql 的 crud 操作转移到基于语义 web 的 crud 操作。了解如何使用 php 通过基于语义的 web 执行 crud 操作。 常用缩写词

api — 应用程序编程接口(application programming interface)

crud — 创建/读/更新/删除(create/read/update/delete)

http — 超文本传输协议(hypertext transfer protocol)

mvc — 模式—视图—控制器(model-view-controller)

oop — 面向对象的编程(object-oriented programming)

rdf — 资源描述框架(resource description framework)

sparql — 简单协议和 rdf 查询语言(simple protocol and rdf query language)

sql — 结构化查询语言(structured query language)

ui — 用户界面(user interface)

w3c — 万维网联盟(world wide web consortium)

在开发 web 应用程序时,为逻辑层和 ui 层创建放置服务器端代码的数据库结构是一种标准实践。要连接到数据库,服务器端代码需要执行一些基本的创建、更新、删除和 — 最重要的 — 读取记录等操作。由于 web 应用程序的后台数据库通常都是关系数据库,因此这些 crud 操作都是使用众所周知的 sql 语言执行的。但是,随着 web 开发越来越多地采用面向对象的编程(oop),模型也随之发生改变。

资源描述框架(resource description framework,rdf)是描述对象同时保留数据含义的理想方法。简单协议和 rdf 查询语言(simple protocol and rdf query language,sparql — 发音为 “sparkle”)是通常用于针对该数据进行查询的语言,因为它在语句构成上匹配 rdf 本身的结构。rdf 和 sparql 都是所谓 语义 web 栈(semantic web stack)中的技术。

要彻底地应用语义 web 理念,您可以使用 sparql 将传统的 web 开发技术应用到 rdf 数据中。本文将展示如何使用简化的模式—视图—控制器(model-view-controller,mvc)设计模型、php 服务器端脚本语言和 sparql 连接到 rdf — 与使用关系数据库系统中的 sql 相反。

sql 和 sparql crud 操作

先决条件 本文假定您基本了解 sql、php 和 web 应用程序开发。了解语义 web 也十分有利。要对基于语义 web 的数据运行 create、update 和 delete 命令,需要具有支持 sparql/update 规范的语义 web 数据库。

在使用 sql 和 sparql 进行开发时,需要查看一下 crud 操作之间的异同。清单 1 显示了 read 操作的 sql 代码。

select realname, dob, locationfrom usertable where realname = "john smith";

将这段基于 sql 的代码与清单 2 中所示的基于 sparql 的代码相比较。采用这两个 read 操作的原因在于它们最易于理解、实现和说明。这对于 sql 和 sparql 来说都是一样的。

prefix foaf:<http://xmlns.com/foaf/0.1/> prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>select ?uri ?name ?dob ?locationfrom<http://www.example.org/graph>where{ ?urirdf:type foaf:person ;foaf:name "john smith" ;foaf:birthday?dob ;foaf:location ?location .} ;

在比较两张清单时,您的第一个想法很可能是 sparql 版本明显比 sql 版本长很多。这是事实,但是请不要误以为 sql 必然更简单而且更干净。根据所运行引擎的不同,sparql 可以全部通过称为链接数据结果(linked data effect)的内容进行分发。此外,它允许拥有动态模式,因为它拥有互相链接的面向对象的透视图,与严格的 sql 关系透视图形成对照。如果您想要把关系数据库表分隔为许多数据孤岛,则实际上使用的 sql 代码行将比 sparql 多很多 — 更不必说 sql 中会出现大量令人讨厌的 join 描述符。

sparql 的前两行是 prefix 声明。根据语义 web 理论,一切内容 — 无论是对象还是数据图来源(也是一个对象)— 都有统一资源标识符(uniform resource identifier,uri)。prefix 行只是将临时标签应用到一些 uri 中 — 在本例中为 friend of a friend 和 rdf 模式。其中的好处是您以后可以在查询中使用 prefix 声明而不必使用完整的 uri。

sparql 代码的下一行描述了查询请求。这条语句在本质上与 sql 语句相同,不同之处是对 uri 的附加请求。注意问号的使用(?)是为了表示术语是变量。

from 语句描述了获取数据的位置。这在 sql 和 sparql 中是相同的,只是在 sparql 中,数据源名称是 uri,而非表示计算机或网络中某个物理位置的字符串。

两者的 where 语句完全不同,因为使用 sparql,必须指定用于获取数据的模式。同样,如果尝试过使用关系方法执行此操作,则需要花费的代价比普通 sql 多得多:需要使用 php、java? 编程语言或者一些其他服务器端语言才能执行数据源之间的检查。sparql 代码行完成的操作比较明了,这包括确保正在检索的数据只属于 person 类型。sparql 将获取名称和位置,同时执行一些模式匹配以查找正确的 john smith。

创建

sparql 中的 crud 操作通常比 read 操作更神秘。但是,可以完成这些操作。首先,create 操作将把新记录或对象插入到表或图表中。

insert into usertable (realname, dob, location) values ("john smith", "1985-01-01", "bristol, uk");

现在,比较清单 3 中基于 sql 的代码与清单 4 中基于 sparql 的代码中的 create 操作。

prefix foaf:<http://xmlns.com/foaf/0.1/> prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>insert into graph <http://www.example.com/graph> (?realname, ?dob, ?location) {<http://www.example.org/graph/johnsmith#me> rdf:type foaf:person ; foaf:name "john smith" ; foaf:birthday <1985-01-01t00:00:00> ; foaf:location "bristol, uk" }