php mysql 图像_将图像插入MySQL并使用PHP检索图像

此文可能比较繁琐,有更好的方法,但是出于教程目的,这是我的"“最佳实践”的路线。

今天,我们将讨论一个似乎每个人都有些困惑的话题……在MySQL中存储BLOB图像,然后使用PHP再次显示它们。尽管始终建议不要这样做,但我先展示一些演示代码,说明如何实现此目标,并讨论为什么/为什么不这样做。然后,讨论一些替代方案,以及为什么与直接将图像直接存储到数据库相比。

因此BLOB或“Binary Large Objects”是数据库中用于存储原始二进制数据的字段。这些数据可能代表图片,文件或二进制格式的文本。由于这些类型的对象相当大(甚至可能是千兆字节大小),因此该字段旨在容纳大量信息。我们如何在PHP中使用这些字段来插入个人资料图片?

1、我们必须将图像读取为二进制。

2、我们必须准备将其插入数据库(转义)。

3、我们使用典型的SQL将其插入数据库中

对于我们的示例,我们将使用三步过程...

1、设置文档的内容类型以使其与图片类型相匹配(对于jpg图片,图像/ jpeg)

2、在数据库中找到图像并将其拔出

3、显示它

//图片由表单提交。打开它进行阅读(模式“ r”)

$ fp = fopen($ _ FILES ['file_name'] ['tmp_name'],“ r”);

//如果成功,则使用文件大小(以字节为单位)作为长度从文件指针读取。 如果($ fp){

$ content = fread($ fp,$ _FILES ['file_name'] ['size']);

fclose($ fp);

//在内容中添加斜杠,以便转义特殊字符。 //如前所述,在这里也可以使用mysql_real_escape_string。你的选择。 $ content =加号($ content);

//将我们的二进制数据字符串(“内容”)插入到“图像”列的表“表”中 mysql_query(“插入表(image)值('$ content')”);

}

在这里,我们打开文件进行读取并将图像读取到变量中。对该fread()的调用正在读取图像的字节,因此我们为其指定了图像文件的字节长度。可以使用“ size”键从$ _FILES数组中获得。一旦将其包含在变量中,只需将其插入表中“ BLOB”类型的列中即可。在我们的示例中,“图像”列是“ BLOB”数据类型。确保您在MySQL中选择的BLOB也足够大以容纳数据,因为MySQL确实具有不同大小的BLOB数据类型。

//读取我们要从数据库中提取的行。

$ result = mysql_query(“从ID = 1的表中选择图像”);

//如果成功,则以行的形式获取该行,并将“ image”列中的数据存储到变量中。如果($ result){

如果($ row = mysql_fetch_array($ result)){

$ img = $ row [“ image”];

}

}

//将此页面的内容类型设置为image / jpeg,因为我们要拉出的图像是jpg图像。header(“ Content-type:image / jpeg”);

//回显图像。回显“ $ img”;

在这里,我们使用行的ID查找所需的图像。然后,我们从“图像”列中提取数据,并将其放入一个变量中,我们将在一秒钟内回显该变量。在将页面的标题设置为image / jpeg的内容类型之后,我们可以从变量中回显二进制数据。

现在请记住,

在header()调用之前无法打印任何内容。如果这样做,即使打印一个空格,它也会刷新标题并在您尝试再次调用header()时导致错误。注意:错误将与“标题已发送”类似。

此过程与也具有Blob字段的其他数据库非常相似。这里的想法是,我们要获取一个二进制对象,将其作为转义的字符串插入,读回并以告诉浏览器我们正在显示图像数据的内容类型进行显示。

那么为什么我们不应该将图像存储到这样的数据库中呢?数据库(尤其是MySQL)非常适合快速查找数据和短数据块。数据库通常会获取这些数据并将其分解为可快速在磁盘上定位的页面。像BLOB这样的大字段确实使数据库膨胀,并且我们平时也会享受到了它的优势,例如在搜索中使用文件名。但!使用大量二进制数据来膨胀数据库可能会降低查询速度,因为然后数据库被迫(可能)读取2 GB的BLOB以便进行显示。所以当然不能这么做。

解决方案:

将大型文件作为二进制文件存储在数据库中,保持数据库的精简并在数据库中存储文件的路径.

可以将其视为指向对象的指针。如果需要显示图像,则可以在数据库中查找该字段,获取文件路径,然后使用该路径从磁盘上定位图片以进行显示。这给您带来两个好处:1、将数据库必须管理的数据保持在最低限度(又称其占用空间); 2、使用文件路径,我们可以使用查询来搜索它,以按文件名查找文件。

那么,为什么要有BLOB字段呢?如果您的图像很小(例如图标),则该字段可能是一件好事。我也不建议在数据库中使用大量图标,但是可以在不引起过多性能噩梦的情况下使用一小块二进制数据。但是将数据库留给文件系统管理简单的快速数据片段和大文件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/530346.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用Maven逆向工程生成mybatis映射文件

一&#xff0c;pom.xml 注意修改逆向工程配置文件的路径 <build><pluginManagement><plugins><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1…

mysql update多个表_mysql update 多表 (复制)

定我们有两张表&#xff0c;一张表为Product表存放产品信息&#xff0c;其中有产品价格列Price&#xff1b;另外一张表是ProductPrice表&#xff0c;我们要将ProductPrice表中的价格字段Price更新为Price表中价格字段的80%。在Mysql中我们有几种手段可以做到这一点&#xff0c;…

ORA-00907:missing right parenthesis缺少右括号

一&#xff0c;有嵌套查询&#xff0c;并且子查询中用了union all合并两个查询时&#xff0c;前一个查询用了order by&#xff0c;那么会报错并提示ORA-00907:missing right parenthesis缺少右括号&#xff1a; select * from ( select t.* from emp t where t.jobMANAGER ord…

mysql重复记录大于十的数据库_面试官:在使用mysql数据库时,遇到重复数据怎么处理?...

前言前段时间&#xff0c;很多人问我能不能写一些数据库的文章&#xff0c;正好自己在测试mysql数据库性能的时候&#xff0c;出现了一个问题&#xff0c;也就是出现了很多重复的数据&#xff0c;想起来自己long long ago写过一篇类似的&#xff0c;仅此就拿来总结了一下。如果…

线程组的概念

一&#xff0c;线程组和线程的结构&#xff1a;树形结构 每个Thread必然存在于一个ThreadGroup中&#xff0c;Thread不能独立于ThreadGroup存在。 执行main()方法线程的名字是main 如果在new Thread时没有显式指定&#xff0c;那么默认将父线程&#xff08;当前执行new Threa…

mysql中ak替换键_数据库:唯一性约束_alternate key(替换键) mySQL Oracle 数据库 ak 唯一性约束...

数据库:唯一性约束_alternate key(替换键) mySQL Oracle 数据库 ak 唯一性约束数据库:唯一性约束所谓唯一性约束(unique constraint)不过是数据表内替代键的另一个名称而已。替代键(alternate key)可以是数据表内不作为主键的其他任何列&#xff0c;只要该键对该数据表唯一即可…

Oracle自定义类型

Oracle自定义类型可以通过type/create type来声明或者创建 一&#xff0c;四种创建方式 1.1&#xff0c;使用create type创建object类型 create or replace type obj_type as object(id number,name varchar2(50 byte),birthday date); 1.2&#xff0c;使用create type创建…

Oracle/mysql查询语句的执行过程

执行顺序 from on join/pivot/unpivot(mysql没有pivot和unpivot) where group by having select distinct order by limit&#xff08;oralce没有&#xff09; 书写顺序 select distinct <select_list> from <left_table> <join_type>join <righ…

mysql定时sql脚本_定时执行的SQL脚本

因为要同步一个表&#xff0c;所以每天要同步一次数据&#xff0c;但是对SQL不是精通的我&#xff0c;为了测试写了一段代码来测试定时功能创建一个存储过程&#xff0c;是用来插数据的&#xff0c;没有输出和输出参数create or replace procedure temp_pro asbegininsert into…

mysql xml语句_Mysql语句

xml文件转义字符处理(1)(2)直接写转义后的字符1、mysql里批量修改表内某个字段内的部分数据UPDATE inventory_stockSET batchno REPLACE(batchno,-20-201901,-50-2019)2、ON DUPLICATE KEY UPDATE根据主键判断是新增还是修改(也可以有两个或多个主键)INSERT INTO TABLE (a,c) …

destoon网站mysql分表_destoon : 常用数据库操作

destoon在初始化系统后系统会自动连接数据库&#xff0c;并将数据库操作对象保存在$db。对于数据库操作方法参考include/db_mysql.class.php函数原型&#xff0c;我来写几个常用数据库操作。1、读取单条信息$S $db->get_one("SELECT * FROM {$DT_PRE}table WHERE xxxy…

delphi7 mysql控件_Delphi7连接MySql数据库-DBGrid控件显示数据

一个简单的Delphi7小程序&#xff0c;使用MySql数据库做简单查询&#xff0c;用DBGrid控件显示结果&#xff0c;实现过程如下&#xff1a;(1)在MySql中新建demouser表&#xff0c;插入记录用于测试。(2)在Delphi7中新建项目。(3)在From中添加组件。组件Panel&#xff1a;pnl1组…

for循环false 终止 python_python3.5.1给用户3次无效的尝试,然后终止pgm(Simple FOR循环)...

我需要帮助(新生-2周)。我想得到这段代码可能的最微小的变化&#xff0c;允许用户3次在程序中输入错误的值。输入错误值3次后&#xff0c;程序应终止。唯一的要求是代码必须包含FOR循环。我不知道它是需要一个FOR循环还是3个FOR循环(每次转换一个)。我尝试了很多种方案&#xf…

mysql何时会走索引

访问类型&#xff0c;这里只列出最常见的6种类型 all,index,range,ref,eq_ref&#xff0c;const mysql中explain的type的解释_dennis211的博客-CSDN博客_explain type 使用不同的运算符时访问类型不一样&#xff1a; !、not in、<>、>、<、in(多个值)、or、bet…

mysql数据库唯一性_在MySQL数据库中添加唯一性约束,范围可能吗?

我有一个使用MySQL的Rails应用程序。我在两个模型之间有一个has_many :through关联&#xff0c;如下所述&#xff1a;class Category < ActiveRecord::Basehas_many :category_pairingshas_many :dishes, through: :category_pairings, :inverse_of > :categoriesendclas…

filtic函数 matlab_matlab filtic 函数应用 filter 解差分方程 dft 函数

matlab filtic 函数应用 filter 解差分方程 dft 函数一、 解差分方程说明都在代码注释里面了%这里要利用filtic函数 为滤波器的直接II型实现选择初始条件%求解查分方程 y(n) - 0.4y(n-1) - 0.45y(n-2) 0.45x(n) 0.4x(n-1) - x(n-2)%y(-1) 0 y(-2) 1 x(-1) 1 x(-2) 2%x(n)…

rabbitmq进阶一

上一篇文章有讲到rabbitmq的安装、web管理端和springboot简单集成rabbitmq 本文重点介绍rabbitmq相关api的使用 按照官网常用的五种模式的顺序&#xff1a;HelloWorld、Work queues、Publish/Subscribe、Routing、Topics 模式简单介绍 HelloWorld 一个生产者&#xff0c;一…

mysql 相关搜索_MySQL单词搜索相关度排名

一个单词搜索的相关度排名,这个例子演示了一个单词搜索的相关度排名计算。mysql> CREATE TABLE articles (-> id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,-> title VARCHAR(200),-> body TEXT,-> FULLTEXT (title,body)-> ) ENGINEInnoDB;Query O…

IDEA使用总结

idea中使用tomcat IntelliJ IDEA配置Tomcat&#xff08;完整版图文教程&#xff09;_猿Bug的博客-CSDN博客_intellij tomcat配置 用上面的方式发现缺少文件&#xff0c;在edit configuration页面选择before lanuch前选择Run maven goal package

mysql一直copying to tmp table_mysql提示Copying to tmp table on disk

网站运行的慢了&#xff0c;查找原因是Copying to tmp table on disk那怎么解决这个问题呢解决一例最近常常碰到网站慢的情况&#xff0c;登陆到后台&#xff0c;查询一下 /opt/mysql/bin/mysqladmin processlist;发现一个查询状态为&#xff1a; Copying to tmp table 而且此查…