资讯内容
使用Python把图片存入数据库
Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
一般情况下我们是把图片存储在文件系统中,而只在数据库中存储文件路径的,但是有时候也会有特殊的需求:把图片二进制存入数据库。Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
MYSQL是支持把图片存入数据库的,也相应的有一个专门的字段BLOB(Binary Large Object),即较大的二进制对象Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
还有个更大的存二进制的LONGBLOB;Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
这里需要注意:尽量把字段设置大一些,因为如果设置的字段长度过小,就会出现图片只显示一部分的情况。第二:如果数据量大的话尽量避免使用这种方式进行,因为mysql对于大数据的查询速度会很慢。Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
1、首先读取文件,用open()和close()打开和关闭;Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
2、接着用connect()创建数据库连接;Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
3、用Binary()指定存储的是二进制;Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
4、然后数据库提交,关闭数据库即可。Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
下面是具体的代码:Iyi少儿编程网-Scratch_Python_教程_免费儿童编程学习平台
#!/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)- 上一篇
零基础自学Python要多久才能学会?
简介零基础自学Python要多久?学习Python开发的周期因人而异,由于基础、学习效率不同有的人学习进度快,需要六个月到一年不等,有的人自律性较差可能需要更久的时间才能学会,今天小编分享下6个月学习周期内的自学Python的学习路线。零基础自学Python学习路线:一、基础篇安装python2.7,利
- 下一篇
如何查看mysql日志
简介MySQL日志主要包含:错误日志、查询日志、慢查询日志、事务日志、二进制日志。查看日志信息的方法:mysql> show global variables like '%log%';+----------------------