怎样将保存在Mysql的long blob类型字段中的文件下载下来?

怎样将保存在Mysql的long blob类型字段中的文件下载下来?,第1张

如果要读出BLOB数据,首先你要知道这个字段里存的是哪种流,是图片,还是文件,这样你读取输出以后也知道文件类型

ResultSet里面有getBlob方法,你可以查下API

文件保存到数据库或文件,数据库只是记录路径,当然是数据库记录路径好了。

你想想把,如果传一个电影2G,到你数据库一存,会有什么后果呢。

PHP下载代码:

<?php

header('Expires: Mon, 26 Jul 1997 05:00:00 GMT')

header('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT')

header('Cache-Control: no-cache, must-revalidate')

header('Pragma: no-cache')

header('Content-Encoding: none')

header('Content-Length: '.$filesize)

header('Content-Disposition: attachmentfilename='.$attach['filename'])

header('Content-Type: '.$attach['filetype'])

@$fp = fopen($filename, 'rb')

@flock($fp, 2)

$attachment = @fread($fp, $filesize)

@fclose($fp)

echo $attachment

?>

text字段类型是允许存放65535字节内的文字字符串字段类型。

longtext字段类型是允许存放2147483647字节内的文字字符串字段类型。

mediumtext字段类型是允许存放16777215字节内的文字字符串字段类型。

mysql中text,longtext,mediumtext字段类型区别为:字节限制不同、I/O不同、行迁移不同。

一、字节限制不同

1、text字段类型:text字段类型的字节限制为65535字节。

2、longtext字段类型:longtext字段类型的字节限制为2147483647字节。

3、mediumtext字段类型:mediumtext字段类型的字节限制为16777215字节。

二、I/O不同

1、text字段类型:text字段类型比longtext、mediumtext字段类型更不容易造成多余的I/O。

2、longtext字段类型:longtext字段类型比text、mediumtext字段类型更容易造成多余的I/O。

3、mediumtext字段类型:mediumtext字段类型比text字段类型更容易造成多余的I/O,比longtext字段类型更不容易造成多余的I/O。

三、行迁移不同

1、text字段类型:text字段类型比longtext、mediumtext字段类型更容易进行行迁移。

2、longtext字段类型:longtext字段类型比text、mediumtext字段类型更不容易进行行迁移。

3、mediumtext字段类型:mediumtext字段类型比text字段类型更不容易进行行迁移,比longtext字段类型更容易进行行迁移。

1.

blob是二进制大对象,可以容纳可变量数量的数据,其中blob分为4中类型:TINYBLOB,BLOB,mediumblob和LongBlob,他们容纳的长度是不同的.

Text同样也分为四种类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT

2.

blob被视为二进制字符串,Text被视为非二进制字符串

blob列没有字符集,并且排序和比较基于列值字节的数值值。

TEXT列有一个字符集,并且根据字符集的校对规则对值进行排序和比较。

在MySQL TEXT或BLOB列的存储或检索过程中,不存在大小写转换,当未运行在严格模式时,如果你为BLOB或TEXT列分配一个超过该列类型的最大长度的值值,值被截取以保证适合。如果截掉的字符不是空格,将会产生一条警告。

使用严格SQL模式,会产生错误,并且值将被拒绝而不是截取并给出警告.在大多数方面,可以将BLOB列视为能够足够大的VARBINARY列。同样,可以将TEXT列视为VARCHAR列。

3.

BLOB和TEXT在以下几个方面不同于VARBINARY和VARCHAR.

BLOB和TEXT列不能有默认值.

当保存或检索BLOB和TEXT列的值时不删除尾部空格。(这与VARBINARY和VARCHAR列相同).

对于BLOB和TEXT列的索引,必须指定索引前缀的长度。对于CHAR和VARCHAR,前缀长度是可选的.

LONG和LONG VARCHAR对应MEDIUMTEXT数据类型。这是为了保证兼容性。如果TEXT列类型使用BINARY属性,将为列分配列字符集的二元校对规则.

MySQL连接程序/ODBC将BLOB值定义为LONGVARBINARY,将MySQL TEXT值定义为LONGVARCHAR。由于BLOB和TEXT值可能会非常长,使用它们时可能遇到一些约束.

BLOB或TEXT对象的最大大小由其类型确定,但在客户端和服务器之间实际可以传递的最大值由可用内存数量和通信缓存区大小确定。你可以通过更改 max_allowed_packet变量的值更改消息缓存区的大小,但必须同时修改服务器和客户端程序。例如,可以使用 MySQL和MySQLdump来更改客户端的max_allowed_packet值.


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/8611157.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-18
下一篇2023-04-18

发表评论

登录后才能评论

评论列表(0条)

    保存