PostgreSQL大对象操作办法

大对象操作办法:

1.在PG中创建N个大对象,一个大对象即为一个OID。

select lo_create(0); //返回大对象的oid。

2.-- 写入数据到大对象,此处数据应该是上面导出的一行的列的二进制值

SELECT lo_write(large_object, 'Hello, Large Object!');

1.导出每个二进制的值,针对每个值建个大对象。

2.在原始表中把bytea字段改成OID类型。

//假设这是一个图像表,有一个字段名字,一个字段图像数据。这个oid类型就是一个大对象。

CREATE TABLE image(name text, raster oid);

//那么往图像里插入数据时,针对大对象字段就该调用函数lo_import,这是本地的文件导入进去:

INSERT INTO image VALUES('image1', lo_import('/tmp/screenshot.png'));

其实执行lo_import就会在pg里面生成大对象,这个大对象有自己的oid,底层是一个单独的数据文件,和表文件的存储隔离开来的。

可以通过select * from FROM pg_largeobject查询到这个大对象的一些信息。

所以针对那种表,有多少行记录意味着也就有多少大对象,且需要将表的那个字段的值,最好先搞下来再导入。

postgres=# INSERT INTO image VALUES('image1', lo_import('/tmp/screenshot.png'));

INSERT 0 1

postgres=# SELECT loid, COUNT(page no) FROM pg_largeobject GROUP BY loid;

loid | count

-------±------

24598 | 25

(1 row)

postgres=# SELECT raster, lo_export(raster, '/tmp/screenshot-e.png') FROM image WHERE name = 'image1';

raster | lo_export

--------±----------

24598 | 1

(1 row)

postgres=# ! md5sum /tmp/screenshot.png /tmp/screenshot-e.png

dc51d60215f547a897d4d73beba65ded /tmp/screenshot.png

dc51d60215f547a897d4d73beba65ded /tmp/screenshot-e.png

相关推荐
TechWayfarer8 小时前
IP精准定位服务在保险行业的接入实践:区域需求洞察与精准服务
数据库·python·tcp/ip·flask
KKKlucifer8 小时前
数据分类分级产品排名解析:场景定制、规则联动、增量更新成核心能力
大数据·数据库·人工智能
minji...8 小时前
MySQL数据库 (七) MySQL表的基本查询(上),insert、replace、select、where、order by
数据库·mysql·select·replace·insert·order by·where
金融RPA机器人丨实在智能8 小时前
数据库运维Agent比价指南:国产自研产品适配国产数据库兼容性更好吗?
运维·数据库·人工智能·ai
IT策士8 小时前
Redis 从入门到精通:持久化RDB 与 AOF
数据库·redis·缓存
gerrywhu9 小时前
【应用实践】PostGIS实现NDVI计算与植被覆盖分级统计分析-以武汉市2025年为例
数据库·postgis·栅格数据分析·st_mapalgebra·ndvi计算·植被覆盖分级统计·植被覆盖计算
QiLinkOS9 小时前
极客与商业思维的融合实践(1)
c语言·数据库·c++·人工智能·算法·开源协议
chushiyunen9 小时前
高斯数据库笔记、gaussDb
数据库·笔记
ZengLiangYi9 小时前
本地向量数据库选型:vectra vs chroma vs hnswlib
javascript·数据库·后端
TDengine (老段)10 小时前
TDengine 逻辑计划生成 — 从 AST 到关系代数算子树
大数据·数据库·物联网·wpf·时序数据库·tdengine·涛思数据