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

相关推荐
fengxin_rou12 小时前
【MySQL 三大日志深度解析】:redo log、undo log、binlog 作用与两阶段提交原理
数据库·mysql·日志·redo log
ECT-OS-JiuHuaShan12 小时前
存在是微分张量积,标量是参数但不可能是本质。还原论泛化,是语义劫持和以偏概全的逻辑谋杀伪科学庞氏骗局
数据库·人工智能·算法·机器学习·数学建模
IT策士12 小时前
Django 从 0 到 1 打造完整电商平台:使用 Django 消息框架与用户权限初步
数据库·django·sqlite
星河耀银海12 小时前
JAVA 注解(Annotation):从原理到实战应用
java·开发语言·数据库
lzp079112 小时前
基于多模态视觉模型和图文向量模型的工业图像知识库研究与应用(伍)
数据库·学习·neo4j
sunshine88512 小时前
合并报表自动化:数据治理如何助力集团企业突破成本与合规瓶颈?
大数据·数据库·人工智能
云边有个稻草人12 小时前
金仓数据库KingbaseES自动创建表空间目录:简化运维,适配国产生态
数据库·数据加密·kingbasees·信创适配·国产化数据库·表空间自动创建
imuliuliang12 小时前
Laravel5.x核心特性全解析
android·运维·数据库·nginx
Miss roro12 小时前
企业合同管理系统选型的核心维度:功能完整性、协作效率与安全合规
java·数据库·安全·法律科技
Irene199112 小时前
数据库锁机制:表锁、行锁(Oracle 默认)、共享锁、排他锁、乐观锁、悲观锁、死锁、Hive 中的锁
数据库