一般情況下我們是把圖片儲存在檔案系統中,而只在資料庫中儲存檔案路徑的,但是有時候也會有特殊的需求:把圖片二進位制存入資料庫。
今天我們採用的是python+mysql的方式
MYSQL 是支援把圖片存入資料庫的,也相應的有一個專門的欄位 BLOB (Binary Large Object),即較大的二進位制物件
還有個更大的存二進位制的LONGBLOB;
這裡需要注意:儘量把欄位設定大一些,因為如果設定的欄位長度過小,就會出現圖片只顯示一部分的情況。第二:如果資料量大的話儘量避免使用這種方式進行,因為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)