我想知道如何为一个相当简单的php网站编写XML数据层.原因是:
该模式类似于一个简单的图书目录,其中包含一些查找表和i18n.因此,表达起来非常简单.
主xml文件的大小在100kb到15mb的范围内.但它可能会在某种程度上增长到~100mb.
我实际上正在考虑扩展我的模型类来处理xml数据.目前我使用XMLReader和SimpleXml的组合来获取数据,如下所示:
public function find($xpath){
while($this->xml_reader->read()){
if($this->xml_reader->nodeType===XMLREADER::ELEMENT &&
$this->xml_reader->localName == 'book' ){
$node = $this->xml_reader->expand();
$dom = new DOMDocument();
$n = $dom->importNode($node, true);
$dom->appendChild($n);
$sx = simplexml_import_dom($n);
// xpath returns an array
$res = $sx->xpath($xpath);
if(isset($res[0]) && $res[0]){
$this->results[] = $res;
}
}
return $this->results;
}
Run Code Online (Sandbox Code Playgroud)
因此,我不是将整个xml文件加载到内存中,而是为每个部分创建一个SimpleXml对象,并对该对象运行xpath查询.该函数返回SimpleXml对象的数组.对于保守搜索,我可能会破坏第一个找到的项目.
我要问的问题是:
如果你有锯子,你需要敲钉子,不要使用锯子.得到一把锤子.(民间谚语)
换句话说,如果您想要数据存储,请使用数据库,而不是标记语言.
PHP通过PDO对各种数据库系统提供了很好的支持; 对于小型数据集,您可以使用SQLite,它不需要服务器(它存储在普通文件中).之后,如果您需要切换到功能齐全的数据库,这很简单.
回答你的问题:
5A.SQLite的设计考虑了非常小而简单的数据库 - 简单,没有服务器依赖(db包含在一个文件中).正如@Robert Gould 在评论中指出的那样,它不适用于较大的应用程序,但随后
5B.对于中型到大型数据存储,考虑一个关系数据库(通常更容易切换数据库而不是从XML切换到数据库).
归档时间: |
|
查看次数: |
568 次 |
最近记录: |