MySQL varbinary类型存储文件的方法

avatar
作者
筋斗云
阅读量:0

在MySQL中,可以使用VARBINARY类型来存储文件

  1. 创建一个包含VARBINARY类型字段的表:
CREATE TABLE files (     id INT AUTO_INCREMENT PRIMARY KEY,     file_name VARCHAR(255) NOT NULL,     file_data VARBINARY(MAX) NOT NULL,     file_size INT NOT NULL,     file_type VARCHAR(255) NOT NULL ); 

这里,我们创建了一个名为files的表,其中包含以下字段:

  • id: 自动递增的主键。
  • file_name: 文件名。
  • file_data: 文件数据,使用VARBINARY(MAX)类型存储。
  • file_size: 文件大小(字节)。
  • file_type: 文件类型(如:image/jpeg、application/pdf等)。
  1. 将文件读取到程序中并转换为二进制数据:

使用编程语言(如Python、Java、PHP等)读取文件内容,并将其转换为二进制数据。以下是一个使用Python的示例:

import os  def read_file_as_binary(file_path):     with open(file_path, 'rb') as file:         return file.read()  file_path = 'path/to/your/file.jpg' file_data = read_file_as_binary(file_path) file_size = os.path.getsize(file_path) 
  1. 将二进制数据插入到数据库中:

将读取到的二进制数据插入到files表中。以下是一个使用Python和MySQL Connector库的示例:

import mysql.connector  def insert_file_to_database(file_name, file_data, file_size, file_type):     connection = mysql.connector.connect(         host='your_host',         user='your_user',         password='your_password',         database='your_database'     )      cursor = connection.cursor()     query = """         INSERT INTO files (file_name, file_data, file_size, file_type)         VALUES (%s, %s, %s, %s)     """     values = (file_name, file_data, file_size, file_type)     cursor.execute(query, values)     connection.commit()     cursor.close()     connection.close()  file_name = 'example.jpg' file_type = 'image/jpeg' insert_file_to_database(file_name, file_data, file_size, file_type) 
  1. 从数据库中读取文件数据并保存到本地:

要从数据库中读取文件数据并将其保存到本地文件,可以使用以下Python代码:

def get_file_from_database(file_name):     connection = mysql.connector.connect(         host='your_host',         user='your_user',         password='your_password',         database='your_database'     )      cursor = connection.cursor()     query = "SELECT file_data, file_type FROM files WHERE file_name = %s"     cursor.execute(query, (file_name,))     result = cursor.fetchone()     cursor.close()     connection.close()      if result:         return result     else:         return None  def save_file(file_name, file_data, file_type):     with open(file_name, 'wb') as file:         file.write(file_data)  result = get_file_from_database('example.jpg') if result:     file_data, file_type = result     save_file('output.jpg', file_data, file_type) 

这样,您就可以将文件存储到MySQL数据库中,并在需要时从数据库中检索文件。请注意,根据您的实际情况替换上述代码中的数据库连接参数。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!