高级材料
insert 和 update
假设现在你要把下面的数据插入到数据库中.
id = 3
thedate=mktime(0,0,0,8,31,2001) /* 31st august 2001 */
note= sugar why don't we call it off
当你使用另外一个数据库的时候,你的插入操作可能不会成功。
第一个问题是每个数据库都有不同的默认日期格式。mysql默认格式是yyyy-mm-dd ,
然而其它数据库有不同的默认格式。adodb有一个dbdate()的函数,它能将日期转
换成正确的格式。
接下来的一个问题是note字段值里的don't 应该作为引文。在mysql中,使用
don\'t 来解决这个问题,但在一些其它的数据库中(sybase, access, microsoft
sql server)使用don''t 。qstr()解决了这个问题。
那么我们怎么使用这个函数呢? 像下面这样:
$sql = insert into table (id, thedate,note) values (. $id . ',' . $db->dbdate($thedate) .',' . $db->qstr($note).);$db->execute($sql);adodb 也支持 $connection->affected_rows() (返回上次update或delete操作影响的
行数) 和 $recordset->insert_id() (返回insert声明生成的上一个自增编号)。但要
说明的是不是所有的数据库都支持这两个函数。
metatypes
你可以找到更多关于你调用recordset的方法fetchfield($fieldoffset)所选择的每个
字段(我同时使用字段和列这两个词)的信息。它将返回一个有三个属性(名称,类
型和最大长度)的对象。
例如:$recordset = $conn->execute(select adate from table);
$f0 = $recordset->fetchfield(0);那么 $f0->name 的值将被设为 'adata', $f0->type 的值将被设为 'date'. 如果
max_length 未知,它被设为-1。
处理不同类型的数据库的一个问题是每个数据库常常用不同的名字来调用相同的类型。
例如timestamp 类型在某一个数据库中叫做datetime 类型,而在另一个是叫做time
类型。 因此 adodb 有个专门的 metatype($type, $max_length) 函数对下面的类型
进行标准化:
c: character 和 varchar 类型
x: text 或者 long character (例如.多于255 字节宽度).
b: blob 或者 binary 图像
d: date
t: timestamp
l: logical (boolean)
i: integer
n: numeric (float, double, money)
在上面的例子中,
$recordset = $conn->execute(select adate from table);
$f0 = $recordset->fetchfield(0);
$type = $recordset->metatype($f0->type, $f0->max_length);
print $type; /* 应该显示 'd' */
select limit 和 top 支持
adodb 有一个叫$connection->selectlimit($sql,$nrows,$offset)的函数,它允许你
获得一个记录集(recordset)的子集。它会在microsoft产品上使用本地的select top,
在postgresql和mysql上使用select ... limit,并在不支持这项功能的数据库上模拟
这个功能。
缓存支持
adodb 允许你在你的文件系统上缓存记录集结果,只需用$connection->cacheexecute($secs2cache,$sql)
和$connection->cacheselectlimit($secs2cache,$sql,$nrows,$offset)在指定的超时
时间段后重新向数据库服务器发出查询。
php4 session 处理接口支持
adodb 也支持php4 session 处理接口. 你可以使用adodb在一个数据库中存储你的
session变量。要获得更多下信息,访问http://php.weblogs.com/adodb-sessions
鼓励作为商业用途
如果你正计划编写你要转售的商业php软件产品,你应该考虑adodb。adodb使用gpl发
布。这意味这你也可以在商业软件中合法的使用它,同时保持你的代码所有权。十分
鼓励adodb作为商业用途!因为上述的原因我们内部也正在使用它。
结束语
作为你能耐心的看完这篇文章的答谢,下面是let's call the whole thing off 的