时间:2015-01-19 11:39 文章来源:http://www.lunwenbuluo.com 作者:钱晓燕 点击次数:
摘 要:在数据库应用系统中,经常需要对图片进行处理,包括图片在数据库中的直接存储和只将图片地址存储于数据库中两种存储方式。本文主要论述了图片的存储方式、读取方式,它们各自的优缺点以及怎样存取才能达到效率最高。
关键词:移植性 数据负担 OlE 对象 图片地址
中图分类号:G718 文献标识码:A 文章编号:1674-2117(2014)22-00-01
在教学中,我们常常会用VB及Access做些小的数据库应用系统,如学籍管理系统、考试系统、图书管理系统等,在这些数据库应用系统中,经常需要对图片进行处理。图片在数据库中应该如何存取、怎样存取才能达到效率最高,是我们最常碰到又急需解决的问题。
1 图片在数据库中的存储
以考试管理系统为例来说,在考试报名界面上必须有考试照片,而这照片必须存入后台数据库中。图书管理系统新书入库时需将新书封面图片存入数据库等。
一般来说,图片在数据库中的存储有两种方式:直接将图片存储在数据库中和在数据库中存储图片地址。
1.1 直接将图片存储在数据库
这种存储方式采用的是数据流技术。数据库设计时,存储图片的字段数据类型定义为“OLE对象”。要插入图片直接双击该字段即可。若要在程序中写入数据库,实现代码如下:
SUB SFILE()
DIM STR As ADODB.STREAM
DIM REAS ADODB.RECORDSET
DIM STR AS STRING
SET STM = NEW ADODB.STREAM
STM.TYPE= ADTYPEBINARY
STM.OPEN
STM.LOADFROMFILE APP.PATH+”\ABC.JPG”
SET RE= NEW ADODB.RECORDESET
RE.OPEN”SELECT * FROM IMG” ,STM,1,3
RE.ADDNEW
RE.FIELDS(“PHOTO”)=STM.READ
RE.UPDATE
RE.CLOSE
STM.CLOSE
END SUB
从代码看图片操作与其他字段写入数据库基本一样,只不过使用的是流对象。它的优点是移植性好,不受系统前台程序约束,可在不同地方使用;缺点是加大了数据库的负担,在图片量大的情况下会导致数据读取、备份等操作缓慢。
联系方式
随机阅读
热门排行