base64格式图片,mysql数据库应该用什么数据类型?

java 将图片转换成base64后,存储到mysql数据库时,数据类型应该用bolob还是longText?如果用bolob,前端怎么显示数据?
(数据库中对应字段不让存地址,不在服务器存图片)

style='width: 500px;height:500px' src=" XXX" />

该回答引用GPTᴼᴾᴱᴺᴬᴵ
如果你将图片转换成base64后存储在MySQL数据库中,可以使用 LONGTEXT 类型的字段来存储数据。BLOB 类型可以存储二进制数据,但是可能会导致性能问题。

在前端页面中,你可以使用 img 标签来显示图片,同时在 src 属性中填写对应的base64编码的图片数据即可,例如:

<img src="data:image/png;base64,iVBORw0KGg..."/>


其中,data:image/png;base64 表示图片的MIME类型以及编码方式,后面跟着实际的base64编码的数据。你可以在前端代码中使用相应的方式来展示存储在数据库中的base64格式的图片。如果你使用了Layui,可以使用其 img 组件来实现图片的展示。

参考GPT和自己的思路:

对于存储base64格式图片到MySQL数据库中,最好使用longtext数据类型,因为它可以存储更长的文本数据,具有更高的灵活性和可拓展性。而如果选择使用blob类型,则必须限制存储的数据大小不能超过特定的大小限制。

在前端显示数据时,可以直接将该longtext类型字段返回到前端,前端可以通过常规解码方式展示图片。例如,可以将该字段的内容插入到标签的src属性中,如下所示:

<img style='width:500px;height:500px' src="data:image/png;base64,base64编码的图片数据" />

其中,base64编码的图片数据指的是存储在longtext字段中的base64编码后的图片数据。这样可以在前端直接将图片呈现出来。

base64都是可显示字符,可以直接按文本存储