2024 年 PHP 开发者大会日本站

dBase 函数

示例

本参考中的许多示例都需要一个 dBase 数据库。我们将使用 /tmp/test.dbf,它将在 dbase_create() 的示例中创建。

目录

添加笔记

用户贡献笔记 2 条笔记

bi.idan AT gmail.com
17 年前
我知道很多人并不真正使用 dbase,但我已经构建了一个类来帮助那些确实使用它的人。
(抱歉,英语不好)

- dbase.php

<?php

set_time_limit
(0);
// site_path 由父级定义
require_once (SITE_PATH. '/server/php/libs/dbase/handler.php');

/* DBase (dbf)
* 管理 dbf 文件,导出和搜索功能
* 带有内置优化器以提高性能
*/

class DBase
{
private
$handler = false;
private
$searchopt = array (); // 搜索优化器

private function unload ()
{
if (
$this-> handler !== false)
unset (
$this-> handler);
}

public function
__construct ($file = false)
{
if (
$file !== false)
$this-> load ($file);
}

public function
__destruct ()
{
$this-> unload ();
}

public function
load ($file)
{
$resource = dbase_open ($file, 0);
$this-> handler = new DBase_Handler ($resource);

return
$this-> handler;
}

/* 搜索
* 在头部搜索字符串
* 返回记录号
* 未找到或发生错误时返回 false
* limit_results 获取整数或 false,limit_results 等于 1 将搜索结果限制为一个结果,false 为无限制
*/
public function search ($headerText, $string, $limit_results = false, $handler = false)
{
if (
$handler === false)
$handler = $this-> handler;

if (
$this-> searchopt [$headerText][$string])
return
$this-> searchopt [$headerText][$string];
else
{
$size = $handler-> getSize ();
if ( (
$headerNumber = $handler-> getHeaderNumber ($headerText) ) !== false)
{
$results = array ();
for (
$i = 1; $i < $size; $i++)
{
$record = $handler-> getRecord ($i, false); // 禁用优化器以防止内存溢出
if (trim ($record [$headerNumber]) == $string)
{
$results[] = $i;

if ( (
$limit_results !== false) && (sizeof ($results) == $limit_results) )
break;
}
}

if (
sizeof ($results) > 0)
{
$this-> searchopt [$headerText][$string] = $results;
return
$this-> search ($headerText, $string, $handler);
}

return
false;
} else
return
false;
}
}
}

?>

- dbase_handler.php

<?php

/* DBase 处理程序 (dbf)
* 处理 dbase 资源
*/

class DBase_Handler
{
private
$resource;
private
$size; // 记录数
private $header = array ();
private
$dataopt = array (); // 数据优化器

private function setHeader ()
{
$this-> header = dbase_get_header_info ($this-> resource);
}

public function
__construct ($resource)
{
$this-> resource = $resource;
$this-> setHeader ();
$this-> size = dbase_numrecords ($this-> resource);
}

public function
__destruct ()
{
dbase_close ($this-> resource);
}

public function
getRecord ($record_number, $dataopt = true)
{
if (
$record_number > $this-> size)
return
false;
else
{
if (
$this-> dataopt [$record_number])
return
$this-> dataopt [$record_number];
else
{
$record = dbase_get_record ($this-> resource, $record_number);
if (
$dataopt === true) // 数据保存优化器
{
$this-> dataopt [$record_number] = $record;
return
$this-> getRecord ($record_number);
} else
return
$record;
}
}
}

public function
getHeaderNumber ($headerText)
{
foreach (
$this-> header as $index => $header)
{
if (
$header ['name'] == $headerText)
{
return
$index;
break;
}
}

return
false;
}

public function
getHeader ($headerNumber)
{
if (
$headerNumber <= sizeof ($this-> header))
return
$this-> header [$headerNumber];
else
return
false;
}

public function
getSize ()
{
return
$this-> size;
}
}

?>
bi.idan [at] gmail.com
15 年前
你们中的一些人曾联系我询问备忘录字段和我的脚本,所以我将在此处发布我对常见问题的解答。

(注意:这不是任何程序的广告,只是我自用的内容,并且它是免费的)

所以,如果你想创建/读取备忘录字段,有两种选择

1. 使用 Java/C++/C# 的库来构建 PHP 和 DBF 文件之间的桥梁。我使用了 dbf2java。虽然它不像我的另一个选择那样完整,但它是一个良好的开端。(http://code.google.com/p/dbf2java-library/)

2. 使用带有管道的外部程序来获取输出。我使用了 cdbflite,(http://www.whitetown.com/cdbflite/)。它是免费的,并且几乎提供了处理这些 DBF 文件所需的一切。我不确定大型数据库的情况,而且似乎你需要注册/购买它,但这同样是一个开端。

希望这能帮助一些需要处理这些数据库文件的人,

祝你好运,
idan
To Top