首頁 >後端開發 >Python教學 >使用python把圖片存入資料庫

使用python把圖片存入資料庫

高洛峰
高洛峰原創
2016-10-18 10:36:301928瀏覽

一般情況下我們是把圖片儲存在檔案系統中,而只在資料庫中儲存檔案路徑的,但是有時候也會有特殊的需求:把圖片二進位存入資料庫。

今天我們採用的是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)


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn