用于从 SQL 操作大对象的服务器端函数在 表 33.1 中列出。
表 33.1. 面向 SQL 的大对象函数
还有一些额外的服务器端函数对应于前面描述的每个客户端函数;实际上,在大多数情况下,客户端函数只是等效的服务器端函数的接口。通过 SQL 命令调用同样方便的函数有 lo_creat
、lo_create
、lo_unlink
、lo_import
和 lo_export
。以下是它们的使用示例
CREATE TABLE image ( name text, raster oid ); SELECT lo_creat(-1); -- returns OID of new, empty large object SELECT lo_create(43213); -- attempts to create large object with OID 43213 SELECT lo_unlink(173454); -- deletes large object with OID 173454 INSERT INTO image (name, raster) VALUES ('beautiful image', lo_import('/etc/motd')); INSERT INTO image (name, raster) -- same as above, but specify OID to use VALUES ('beautiful image', lo_import('/etc/motd', 68583)); SELECT lo_export(image.raster, '/tmp/motd') FROM image WHERE name = 'beautiful image';
服务器端 lo_import
和 lo_export
函数的行为与其客户端对应物截然不同。这两个函数使用数据库所有用户的权限,在服务器的文件系统中读取和写入文件。因此,默认情况下,它们的使用仅限于超级用户。相比之下,客户端导入和导出函数使用客户端程序的权限,在客户端的文件系统中读取和写入文件。客户端函数不需要任何数据库权限,只需要读取或写入所讨论的大对象的权限。
可以将服务器端 lo_import
和 lo_export
函数的使用 GRANT 授予非超级用户,但需要仔细考虑安全隐患。具有此类权限的恶意用户可以很容易地将其转换为超级用户(例如,通过重写服务器配置文件),或者可以攻击服务器的其余文件系统,而无需费力地获取数据库超级用户权限。 因此,对具有此类权限的角色的访问必须像对超级用户角色的访问一样受到严格保护。尽管如此,如果某些例行任务需要使用服务器端的 lo_import
或 lo_export
,那么使用具有此类权限的角色比使用具有完全超级用户权限的角色更安全,因为这有助于降低因意外错误造成的损害风险。
lo_read
和 lo_write
的功能也可以通过服务器端调用获得,但服务器端函数的名称与客户端接口不同,它们不包含下划线。您必须将这些函数称为 loread
和 lowrite
。
如果您在文档中发现任何不正确、与您使用特定功能的体验不符或需要进一步澄清的内容,请使用此表单报告文档问题。