当前位置:首页>滚动 > >正文

详解如何使用beego orm在postgres中存储图片

  • 2023-04-26 06:02:03来源:脚本之家
目录
Postgres如何存储文件bytea类型Large ObjectBeego orm如何存储图片

Postgres如何存储文件

postgres提供了两种不同的方式存储二进制,要么是使用bytea类型直接存储二进制,要么就是使用postgres的LargeObject功能;决定使用哪中方式更加适合你,就需要了解这两种存储方式有哪些限制

bytea类型

bytea类型在单列中虽然可以支持1GB的容量,但是还是不建议使用bytea去储存比较大的对象,因为它会占用大量的内存

下面通过一个例子来说明,假如现在要在一个表中存储图片名和该图片的数据,创建表如下:


【资料图】

CREATE TABLE images (imgname text, img bytea);

在表中插入一张图片:

File file = new File("myimage.gif");
FileInputStream fis = new FileInputStream(file);
PreparedStatement ps = conn.prepareStatement("INSERT INTO images VALUES (?, ?)");
ps.setString(1, file.getName());
ps.setBinaryStream(2, fis, file.length());
ps.executeUpdate();
ps.close();
fis.close();

上面的setBinaryStream就会将图片内容设置到img字段上面,也可以使用setBytes()直接设置图片的内容

接下来,从表中取出图片,代码如下:

PreparedStatement ps = con.prepareStatement("SELECT img FROM images WHERE imgname = ?");
ps.setString(1, "myimage.gif");
ResultSet rs = ps.executeQuery();
if (rs != null) {
    while (rs.next()) {
        byte[] imgBytes = rs.getBytes(1);
        // use the data in some way here
    }
    rs.close();
}
ps.close();

Large Object

Large Object就可以存储大文件,存储的方式是在单独的一张表中存储大文件,然后通过oid在当前表中进行引用;下面通过一个例子来解释:

CREATE TABLE imageslo (imgname text, imgoid oid);

首先是创建一张表,该表中第二个字段类型为oid,之后就是通过该字段引用大文件对象;下面我们在表中插入一张图片:

// All LargeObject API calls must be within a transaction block
conn.setAutoCommit(false);
// Get the Large Object Manager to perform operations with
LargeObjectManager lobj = ((org.postgresql.PGConnection)conn).getLargeObjectAPI();
// Create a new large object
int oid = lobj.create(LargeObjectManager.READ | LargeObjectManager.WRITE);
// Open the large object for writing
LargeObject obj = lobj.open(oid, LargeObjectManager.WRITE);
// Now open the file
File file = new File("myimage.gif");
FileInputStream fis = new FileInputStream(file);
// Copy the data from the file to the large object
byte buf[] = new byte[2048];
int s, tl = 0;
while ((s = fis.read(buf, 0, 2048)) > 0) {
    obj.write(buf, 0, s);
    tl += s;
}
// Close the large object
obj.close();
// Now insert the row into imageslo
PreparedStatement ps = conn.prepareStatement("INSERT INTO imageslo VALUES (?, ?)");
ps.setString(1, file.getName());
ps.setInt(2, oid);
ps.executeUpdate();
ps.close();
fis.close();

在代码中需要使用lobp.open打开一个大文件,然后将图片的内容写入这个对象当中;下面从大文件对象中读取这个图片:

// All LargeObject API calls must be within a transaction block
conn.setAutoCommit(false);
// Get the Large Object Manager to perform operations with
LargeObjectManager lobj = ((org.postgresql.PGConnection)conn).getLargeObjectAPI();
PreparedStatement ps = con.prepareStatement("SELECT imgoid FROM imageslo WHERE imgname = ?");
ps.setString(1, "myimage.gif");
ResultSet rs = ps.executeQuery();
if (rs != null) {
    while (rs.next()) {
        // Open the large object for reading
        int oid = rs.getInt(1);
        LargeObject obj = lobj.open(oid, LargeObjectManager.READ);
        // Read the data
        byte buf[] = new byte[obj.size()];
        obj.read(buf, 0, obj.size());
        // Do something with the data read here
        // Close the object
        obj.close();
    }
    rs.close();
}
ps.close();

需要注意的是,对于Large Object的操作都需要放在一个事务(Transaction)当中;如果要删除大文件所在行,在删除这行之后,还需要再执行删除大文件的操作

注:使用Large Object会有安全问题,连接到数据库的用户,即便没有包含大对象所在列的权限,也可以操作这个大对象

Beego orm如何存储图片

看完上面的postgres对于图片的存储,再来看下如何使用beego orm存储一张图片;在beego orm中支持了go的所有基础类型,但是不支持slice;所以,不能直接将[]byte映射到bytea字段上面

好在beego orm提供了一个Fielder接口,可以自定义类型,接口定义如下:

// Fielder define field info
type Fielder interface {
    String() string
    FieldType() int
    SetRaw(interface{}) error
    RawValue() interface{}
}

所以,现在就需要定义一个字节数组的类型,然后实现这些接口就好了,代码如下:

type ByteArrayField []byte
// set value 
func (e *ByteArrayField) SetRaw(value interface{}) error {
    if value == nil {
        return nil
    }
    switch d := value.(type) {
    case []byte:
        *e = d
    case string:
        *e = []byte(d)
    default:
        return fmt.Errorf("[ByteArrayField] unsupported type")
    }
    return nil
}
func (e *ByteArrayField) RawValue() interface{} {
    return *e
}
// specified type
func (f *ByteArrayField) FieldType() int {
    return orm.TypeTextField
}
func (f *ByteArrayField) String() string {
    return string(*f)
}

然后,我们就可以在struct中进行映射了,如下:

type ImageModel struct{
    ImageName string `orm:"column(image_name)"`
    ImageData ByteArrayField `orm:"column(image_data);type(bytea)"`
}

这样就可以使用orm的接口操作imageModel,向数据库插入图片,或者从数据库读出图片的内容了

以上就是详解如何使用beego orm在postgres中存储图片的详细内容,更多关于beego orm postgres存储图片的资料请关注脚本之家其它相关文章!

标签:

延伸阅读

推荐阅读

详解如何使用beego orm在postgres中存储图片

这篇文章主要为大家介绍了如何使用beegoorm在postgres中存储图片详解,有需要的朋友可以借鉴参考下,希望能

50亿元级项目签约青山湖畔,142.3亿元签约临安,你还不来?

50亿元汽车项目、27亿元科技仪器项目、10亿元医药项目签约青山湖科技城,10亿元新型高分子材料项目签约锦南

世界微头条丨快讯2023-04-26 00:38:33

4月26日电,第一共和银行失去了管理着130亿美元的顾问团队。

【环球报资讯】华能国际电力股份(00902.HK)发布一季度业绩 归母净利约22.5亿元 同比增长335.3%

华能国际电力股份(00902)发布2023年第一季度业绩,营业收入为人民币652

焕新子品牌 首发新车型 红旗品牌携家族明星阵容亮相上海车展

4月18日,红旗品牌上海国际车展媒体发布会隆重举行,中国一汽董事、总经理邱现东出席发布会并致辞,倾情呈

节瓜全雌性状遗传方面取得新进展

近日,广东省农业科学院蔬菜研究所瓜类研究团队在节瓜全雌性状遗传方面取得新进展。相关研究发表于国际学术

有了航海家,周末轻松出游 最新快讯

孩子上学之后,每天都要接送。而且平时周末或者放假的时候,都要带孩子去公园或者郊游。所以给他买了帐篷、

大竹县妈妈镇中心小学开展家庭教育“五进”活动暨“防性侵教育进课堂”专题讲座_天天头条

4月24日,大竹县益心社会工作服务中心一行3人来到大竹县妈妈镇中心小学开展家庭教育“五进”活动暨“防性侵

天天快资讯:孙仁贵

1、孙仁贵。2、男。3、唐代画家。文章到此就分享结束,希望对大家有所帮助。

清镇:营商环境“加法” 促市场活力“乘法”

住建局经开区工作人员走访企业。刘晓丽摄住建局经开区工作人员走访企业。刘晓丽摄物流园区一角。刘晓丽摄清

环球热头条丨绿盟科技:公司无控股股东、无实际控制人。暂无引入国资做大股东的计划

绿盟科技(300369)04月25日在投资者关系平台上答复了投资者关心的问题。

当前简讯:存款流失千亿美元 美国第一共和银行业绩显著恶化

新华社纽约4月24日电(记者刘亚南)总部位于美国旧金山的第一共和银行24日公布业绩报告称,受3月份美国区域

枣阳市吴店镇:打造产业强镇 推动乡村振兴 当前关注

近年来,枣阳市吴店镇聚焦优质稻米主导产业,完善产业链,拓展价值链,努力建设品牌响亮的优质稻米产业强镇

每日看点!鸿富瀚(301086)4月25日主力资金净卖出197.62万元

截至2023年4月25日收盘,鸿富瀚(301086)报收于61 58元,下跌4 48%,换手率1 95%,成交量4220 0手,成交额2648 16万元。

傲农生物澄清大股东质押风险传闻 股价近三个交易日累计跌超20%

连续两个交易日大跌后,4月25日早盘,傲农生物(603363)股价再现显著下行,不过当日午后跌幅已有所收窄,收

锦绣云裳-天天观速讯

模特在广西南宁市广西文化艺术中心展示民族元素服饰(4月24日摄)。4月24日,2022年“锦绣云裳·美丽南宁”

全球即时看!保山货运合同纠纷律师费用怎么算

(一)不涉及财产关系的:2000元-30000元 件。上下浮动幅度:20%但收费额不足2000元的按2000元收取。(二)涉及

三星即将发布的exynos 2400_世界快播

芯片将采用1+2+3+4十核设计,拥有一个3 1ghz的armv+9+cortex-x4内核,2个2 9ghz的armv+9+cortex-a720内核,

郭德纲评书全集在线听聊斋_郭德纲评书全集_环球焦点

1、长篇皮凤山招亲皮凤山发财解学士赶考木莲救母聊斋之鸦头蒋兴哥重会珍珠衫大闹四美堂丑娘娘白宗巍坠楼白

环球快资讯:小杨哥直播间同价!中国「戴森」让吹风机价格狂斩3000元?!速干、不伤发、顺滑...

(点击上方图片进入商城)前段时间给大家推荐了一款超级火爆的国牌吹风机——科西吹风机!现在,小杨哥直播

脑血栓病人能活多长时间 脑血栓病人能活多久|天天热点评

今天来聊聊关于脑血栓病人能活多长时间,脑血栓病人能活多久的文章,现在就为大家来简单介绍下脑血栓病人能

世界聚焦:焦炭供需不佳 焦煤需求承压或震荡偏弱运行

【周一需求端,终端需求不及预期,钢价走弱,今年粗钢限产定调不增不减,焦炭需求承压,周内铁水产量见顶回

汽车也能戴“手表” 五菱宝骏悦也预告:行业首次搭载Car-watch

快科技4月25日消息,国内新能源汽车真是卷出了新高度,就连A0级小车也在想方设法地创新。就在今日,宝骏汽

卡拉格:如果列维不想放人凯恩走不了,不确定球员明夏有多少选择-新消息

在个人社媒上,评论员卡拉格认为,凯恩今夏不会离开热刺。关于凯恩的未来,卡拉格写道:“我想过这个问题,

罗马诺:帕尔梅拉斯与16岁梅西尼奥续约,巴黎曾报价3500万欧遭拒_当前观察

直播吧4月25日讯据名记罗马诺报道,近日帕尔梅拉斯与16岁年轻小将埃斯特旺(球员在巴西国内被称为梅西尼奥

公安部处理灵异事件吗,又比人用附体控制了危害。

公安部处理灵异事件吗,又比人用附体控制了危害。

热点聚焦:投标保证金50万元、选定5家中标单位!安徽宣城2023年屋顶分布式光伏EPC项目二次招标

投标保证金50万元、选定5家中标单位!安徽宣城2023年屋顶分布式光伏EPC项目二次招标4月24日,安徽省宣城市

环球热消息:4月25日 建材类午间行情分析

行情回顾:早盘期货螺纹钢跌27元收3716,热卷跌25元收3788,焦炭跌34 5元收2226,铁矿石跌5 5元收719。现货

北京:4月29日达出京峰值!地铁、公交等运营时间有调整_环球观焦点

合理规划出行路线,尽量避开高峰时段和重点路段,错峰出行,安全出行。

添安重疾无忧保什么?有什么亮点?-天天快资讯

添安重疾无忧是天安财险承保的一款重疾险产品,这款产品最高能支持60周岁人群投保,保障期1年,保障涵盖了1

猜您喜欢

Copyright ©  2015-2022 青年服装网版权所有  备案号:皖ICP备2022009963号-20   联系邮箱:39 60 291 42@qq.com