php mysql blob存图片_php 操作 MySQL 中的Blob类型 存储图片

本文介绍了MySQL中的Blob类型,用于存储大型二进制对象如图片。详细阐述了四种Blob类型的容量差异,并提供了一个PHP示例,展示如何将图片插入数据库以及如何从数据库中读取并显示图片。强调了大文件存储可能对数据库性能的影响。
摘要由CSDN通过智能技术生成

我们需要保存一个文件或者一张图片或者其他二进制或多媒体文件时,经常选择使用Blob类型!

一 基本使用

Blob就是一种Mysql的数据类型,它是一个二进制大型对象,可以作为大量数据的容器;其实更准确地说Blob是一系列数据类型:

MySQL的四种BLOB类型

类型

大小(单位:字节)

TinyBlob

最大255

Blob

最大65K

MediumBlob

最大16M

LongBlob

最大4G

这四种类型除了允许的最大值不同外,没有其他区别;实际使用中根据需要存入的数据大小定义不同的BLOB类型。

注意:如果你存储的文件过大,数据库的性能会下降很多。

图片的插入:

Php代码

0818b9ca8b590ca3270a3433284dd417.png

if($Picture!="none") {

$PSize=filesize($Picture);

$mysqlPicture=addslashes(fread(fopen($Picture,"r"),$PSize));

mysql_connect($host,$username,$password)ordie("Unable to connect to SQL server");

@mysql_select_db($db)ordie("Unable to select database");

mysql_query("INSERT INTO Images (Image) VALUES ($mysqlPicture)")ordie("Cant Perform Query");

}else{

echo"You did not upload any picture";

}

?>

图片的读取:

在知道了如何将图插入数据库之后,我们就需要考虑怎样才能从数据库中取出图片并在HTML页面中显示出来。这个过程要稍微复杂一些,下面我们就来介绍一下实现过程。

因为PHP显示图片需要发送相应的标头,所以我们就会面临这样一个问题,那就是一次只能显示一副图片,因为我们无法在发出标头之后再发送其它的标头。

为了有效的解决这一问题,我们编写了两个文件。其中,第一个文件作为HTML页面的模板,定位图片的显示位置。第二个文件则被用来从数据库中实际输出文件流,作为标签的SRC属性。

第一个文件的简单形式可以如下:

Php代码

0818b9ca8b590ca3270a3433284dd417.png

mysql_connect($host,$username,$password)ordie("Unable to connect to SQL server");

@mysql_select_db($db)ordie("Unable to select database");

$result=mysql_query("SELECT * FROM Images")ordie("Cant Perform Query");

While($row=mysql_fetch_object($result)) {

echo "%5C%22Second.php3?PicNum\">";

}

?>

当HTML页面被浏览时,每显示一副图片就会调用一次Second.php3文件。当第二个文件被调用时会传入相应的Picture ID,我们可以借此从数据库中取回对应的图片并显示。

Second.php3文件如下:

Php代码

0818b9ca8b590ca3270a3433284dd417.png

$result=mysql_query("SELECT * FROM Images WHERE PicNum=$PicNum")ordie("Cant perform Query");

$row=mysql_fetch_object($result);

Header( "Content-type: image/gif");

echo$row->Image;

?>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值