返回顶部
首页 > 资讯 > 后端开发 > GO >详解如何使用beegoorm在postgres中存储图片
  • 415
分享到

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

beegoormpostgres存储图片beegoorm存储 2023-05-17 18:05:46 415人浏览 安东尼
摘要

目录Postgres如何存储文件bytea类型Large ObjectBeeGo ORM如何存储图片Postgres如何存储文件 postgres提供了两种不同的方式存储二进制,要么

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存储图片的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 详解如何使用beegoorm在postgres中存储图片

本文链接: https://lsjlt.com/news/211384.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 详解如何使用beegoorm在postgres中存储图片
    目录Postgres如何存储文件bytea类型Large ObjectBeego orm如何存储图片Postgres如何存储文件 postgres提供了两种不同的方式存储二进制,要么...
    99+
    2023-05-17
    beego orm postgres存储图片 beego orm 存储
  • 如何在MySQL中存储图片
    如何在MySQL中存储图片?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。首先,先要在数据库中建表。我在名为test的数据库下建立了一个叫pic...
    99+
    2024-04-02
  • 我应该如何在 Postgres 中存储 Go 的 time.Location ?
    你在学习Golang相关的知识吗?本文《我应该如何在 Postgres 中存储 Go 的 time.Location ?》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大...
    99+
    2024-04-04
  • python如何在word中存储本地图片
    想要利用Python来操作word文档可以使用docx模块. 安装: pip install python-docx from docx import Document from...
    99+
    2024-04-02
  • Python Matplotlib 中如何用 plt.savefig 存储图片
    目录 前言正文 前言 plt.show()展示图片的时候,截图进行保存,图片不是多么清晰 如何保存高清图也是一知识点 函数包名:import matplotlib.pyplot as pl...
    99+
    2023-09-15
    matplotlib python 开发语言
  • 如何在ASP存储中使用Git?
    ASP存储是一种常用的Web应用程序框架,它提供了一个灵活和可扩展的平台,用于构建各种类型的Web应用程序。Git是一种流行的版本控制系统,它可以帮助我们更好地管理代码并协作开发。在本文中,我们将探讨如何在ASP存储中使用Git。 安装G...
    99+
    2023-08-25
    存储 django git
  • 如何在 Django 中使用 Go 存储缓存?
    Django 是一个流行的 Python Web 框架,而 Go 是一门高效的编程语言。在 Web 开发中,缓存是一个非常重要的概念,它可以大大提高 Web 应用程序的性能。本文将介绍如何在 Django 中使用 Go 存储缓存。 一、什么...
    99+
    2023-11-08
    存储 django 缓存
  • Vue中实现图片上传,上传后的图片回显,存储图片到服务器 【使用对象存储OSS】
    文章目录 1 前提知识1.1 服务端签名后直传1.1.1 流程和源码解析1.1.2 实现步骤 1.2 Aliyun Spring Boot OSS 示例(接入微服务)1.2.1 简略说明1.2.2步骤 2、项目中实际...
    99+
    2023-08-24
    vue.js 服务器 javascript
  • 如何在mysql中使用存储过程
    如何在mysql中使用存储过程?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中...
    99+
    2024-04-02
  • 如何在MySQL中使用存储结构
    这期内容当中小编将会给大家带来有关如何在MySQL中使用存储结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.新建两张数据表:student1, student2新建...
    99+
    2024-04-02
  • 如何在Python中使用Apache存储API?
    Python是一门非常流行的编程语言,广泛应用于各种领域,包括数据分析、机器学习、Web开发等。在这些领域中,数据存储和管理是一个非常重要的问题。Apache存储API是一个非常流行的数据存储解决方案,本文将介绍如何在Python中使用Ap...
    99+
    2023-07-18
    api apache 存储
  • 如何在 Linux 中使用 go-path 存储?
    在 Linux 中,使用 go-path 存储可以帮助我们有效地管理和使用 Go 语言的依赖包。本文将介绍如何在 Linux 中使用 go-path 存储,并演示一些常用的命令和操作。 一、什么是 go-path 存储? go-path 存...
    99+
    2023-07-22
    linux path 存储
  • 详解C++中存储类的使用
    目录auto 存储类register 存储类static 存储类extern 存储类mutable 存储类存储类定义 C++ 程序中变量/函数的范围(可见性)和生命周期。这些说明符放...
    99+
    2022-12-28
    C++存储类使用 C++存储类
  • 怎么在HTML5中使用IndexDB存储图像
    本篇文章为大家展示了怎么在HTML5中使用IndexDB存储图像,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、创建或打开数据库。// IndexedDBwindow.indexedDB...
    99+
    2023-06-09
  • 在android中如何使用缓存和脱机存储
    这篇文章将为大家详细讲解有关在android中如何使用缓存和脱机存储,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、在android中使用缓存和脱机存储  缓存可以加速你的应用程序,即使在...
    99+
    2023-06-25
  • 如何在Android中使用SQLite存储数据
    这篇文章给大家介绍如何在Android中使用SQLite存储数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 安装一个SQLiteDeveloper,这个用来打开android生成的数据库。软件随便搜索就能找到,后面...
    99+
    2023-05-30
    android sqlite
  • 如何在 Laravel 中使用 Go 和 JavaScript 存储?
    Laravel 是一个非常流行的 PHP 框架,它提供了许多强大的功能和工具来帮助开发人员快速构建高质量的 Web 应用程序。但是,在某些情况下,您可能需要使用其他编程语言来进行开发,例如 Go 和 JavaScript。在本文中,我们将探...
    99+
    2023-08-20
    javascript 存储 laravel
  • 如何在Go中使用Bash进行存储?
    在现代软件开发中,存储和处理数据是非常重要的一部分。然而,不同的编程语言和平台提供了不同的解决方案。在这篇文章中,我们将介绍如何在Go中使用Bash进行存储。 Bash是Linux和Unix操作系统中最常用的shell之一。它提供了强大的...
    99+
    2023-11-01
    bash 存储 自然语言处理
  • 如何在 PHP 中使用 MySQL 存储过程?
    要在 php 中使用 mysql 存储过程:使用 pdo 或 mysqli 扩展连接到 mysql 数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭...
    99+
    2024-05-11
    mysql php
  • Python Matplotlib中使用plt.savefig存储图片的方法举例
    目录前言主要功能:函数源码:(根据需要进行选择)参数解释:注意事项:补充:解决plt.savefig() 保存多张图片有重叠的问题总结前言 plt.show()展示图片的时候,截图进...
    99+
    2023-02-14
    plt.savefig存储图片 plt.savefig保存路径 savefig函数
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作