通常、画像はファイル システムに保存され、データベースにはファイル パスのみが保存されますが、画像バイナリをデータベースに保存するという特別なニーズが発生する場合があります。
今日は Python+mysql メソッドを使用します
MYSQL はデータベースへの画像の保存をサポートしており、それに応じて、より大きなバイナリ オブジェクトである特別なフィールド BLOB (Binary Large Object) があります
より大きなバイナリ LONGBLOB もあります
ここで注意してください: フィールドの長さが小さすぎると、画像の一部しか表示されないため、フィールドをできるだけ大きく設定するようにしてください。 2 番目: データの量が多い場合は、mysql がビッグデータをクエリするのに非常に時間がかかるため、この方法の使用は避けてください。
以下のコード:
#!/usr/bin/python #-*- coding: UTF-8 -*- import MySQLdb as mysql import sys try: #读取图片文件 fp = open("./test.jpg") img = fp.read() fp.close() except IOError,e: print "Error %d %s" % (e.args[0],e.args[1]) sys.exit(1) try: #mysql连接 conn = mysql.connect(host='localhost',user='root',passwd='123456',db='test') cursor = conn.cursor() #注意使用Binary()函数来指定存储的是二进制 cursor.execute("INSERT INTO images SET data='%s'" % mysql.Binary(img)) #如果数据库没有设置自动提交,这里要提交一下 conn.commit() cursor.close() #关闭数据库连接 conn.close() except mysql.Error,e: print "Error %d %s" % (e.args[0],e.args[1]) sys.exit(1)