我将jpg图像存储到mysql数据库中。
我使用blob类型在mysql数据库中存储jpg图像。
我使用mysqldump生成一个.sql文件。
我使用.sql文件作为备份并还原数据库。
如何将jpg直接转换为.sql文件?
我尝试了以下python代码:
import os
import base64
archivo_destino = ".\\portada_sql\\archivo.sql"
imagen_origen = ".\\libros_nuevos_jpg\\03000\\000.jpg"
archivo = open(archivo_destino, 'w')
imageFile = open(imagen_origen, "rb")
mi_blob = base64.b64encode(imageFile.read())
archivo.write("INSERT INTO libro_portada VALUES ('"+mi_blob+"');")
archivo.close()
但它不起作用。
是否可以创建一个sql文件,其中的图像存储为blob usign python?
我尽量避免:
将jpg上传到服务器
导入jpg到mysql
将mysql导出到.sql文件
我想直接生成.sql文件。
有可能吗?
1magnus:我提到php是因为我也可以使用php,如果php可以的话。
2埃里克:从上面提到的python代码中,我得到:
插入libro_portada值('b'/9j/4rivrxhpzgaatu0akgaaagabwesaaaaaaaaaaaaae');
从mysqldump我得到:
插入 libro_portada
值('ÿ\ÿ\ကjexif\0\0mm\0*\0\0\0\0\0\0\0\0\0\0\0\0\z\0\0\0\0\0\0\0\0\0b');
1条答案
按热度按时间jk9hmnmh1#
我知道在mysql中存储文件是很疯狂的,但我在这个项目中只是作为一个猴子代码工作。
最后我使用了mysql load_file()函数
我上传了我的jpgs到服务器,并使用mysql load\u file()导入mysql
有很多文件需要上传,所以我创建了一个python脚本来创建sql代码并将其存储在sql文件中。
结果是一个sql文件,每行使用mysql load\u file()插入一个insert命令
我将jpg文件存储在/var/lib/mysql files/中,以便mysql可以导入它。