Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL存储和读取图片

MySQL数据库中存储图片和读取图片的操作代码

作者:蜡笔小新星

在MySQL数据库中存储图片通常有两种主要方式:将图片以二进制数据(BLOB 类型)直接存储在数据库中,或者将图片文件存储在服务器文件系统上,而在数据库中存储图片的路径或URL,以下是这两种方法的详细解释,包括存储和读取操作,需要的朋友可以参考下

方法一:将图片以 BLOB 类型存储在数据库中

MySQL 语句实现

CREATE TABLE images (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(255) NOT NULL,
    image LONGBLOB NOT NULL
);
INSERT INTO images (name, image) VALUES ('example.jpg', LOAD_FILE('/path/to/example.jpg'));

注意:LOAD_FILE() 函数要求 MySQL 服务器对指定路径有读取权限,且该路径必须在 MySQL 服务器的 secure_file_priv 变量指定的目录中(如果启用了该变量)。

SELECT image FROM images WHERE id = 1;

要检索图片数据并将其保存为文件,你可以使用SELECT语句和INTO OUTFILE:

SELECT image FROM images WHERE id = 1 INTO OUTFILE '/path/to/your/output.jpg';

Python 实现

插入图片

import mysql.connector

# 连接到数据库
conn = mysql.connector.connect(
    host='localhost',
    user='your_username',
    password='your_password',
    database='your_database'
)
cursor = conn.cursor()

# 读取图片文件
with open('/path/to/example.jpg', 'rb') as file:
    binary_data = file.read()

# 插入图片到数据库
sql = "INSERT INTO images (name, image) VALUES (%s, %s)"
val = ('example.jpg', binary_data)
cursor.execute(sql, val)
conn.commit()

# 关闭连接
cursor.close()
conn.close()

读取图片

import mysql.connector
from io import BytesIO
from PIL import Image

# 连接到数据库
conn = mysql.connector.connect(
    host='localhost',
    user='your_username',
    password='your_password',
    database='your_database'
)
cursor = conn.cursor()

# 从数据库中读取图片
sql = "SELECT image FROM images WHERE id = 1"
cursor.execute(sql)
result = cursor.fetchone()
image_data = result[0]

# 使用 PIL 库显示图片
image = Image.open(BytesIO(image_data))
image.show()

# 关闭连接
cursor.close()
conn.close()

方法二:将图片存储在文件系统中,并在数据库中存储路径

MySQL 语句实现

CREATE TABLE images (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(255) NOT NULL,
    path VARCHAR(255) NOT NULL
);
INSERT INTO images (name, path) VALUES ('example.jpg', '/path/to/example.jpg');
SELECT path FROM images WHERE id = 1;

Python 实现

保存图片到文件系统并插入路径

import os
import mysql.connector

# 连接到数据库
conn = mysql.connector.connect(
    host='localhost',
    user='your_username',
    password='your_password',
    database='your_database'
)
cursor = conn.cursor()

# 保存图片到文件系统
file_path = '/path/to/save/example.jpg'
with open('/path/to/example.jpg', 'rb') as source_file:
    with open(file_path, 'wb') as dest_file:
        dest_file.write(source_file.read())

# 插入图片路径到数据库
sql = "INSERT INTO images (name, path) VALUES (%s, %s)"
val = ('example.jpg', file_path)
cursor.execute(sql, val)
conn.commit()

# 关闭连接
cursor.close()
conn.close()

读取图片路径并显示图片

import mysql.connector
from PIL import Image

# 连接到数据库
conn = mysql.connector.connect(
    host='localhost',
    user='your_username',
    password='your_password',
    database='your_database'
)
cursor = conn.cursor()

# 从数据库中读取图片路径
sql = "SELECT path FROM images WHERE id = 1"
cursor.execute(sql)
result = cursor.fetchone()
image_path = result[0]

# 使用 PIL 库显示图片
image = Image.open(image_path)
image.show()

# 关闭连接
cursor.close()
conn.close()

总结

选择哪种方法取决于具体的应用场景和需求。

以上就是MySQL数据库中存储图片和读取图片的操作代码的详细内容,更多关于MySQL存储和读取图片的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文