VPS测评介绍
VPS技术分享

MySQL存储二进制的数据,比如说图片文件

如果你想把二进制的数据,比如说图片文件和HTML文件,直接保存在你的MySQL数据库,那么这篇文章就是为你而写的!我将告诉你怎样通过HTML表单来储存这些文件,怎样访问和使用这些文件。  

average credit card debt

  一、本文概述
  本文的主要内容如下:
  *   在MySQL中建立一个新的数据库  
  *   一个怎样储存文件的例子程序  
  *   一个怎样访问文件的例子程序  


  二、在MySQL中建立一个新的database  
  首先,你必须在你的MySQL中建立一个新的数据库,我们将会把那些二进制文件储存在这个数据库里。在例子中我会使用下列结构,为了建立数据库,你必须做下列步骤:  
  1.   进入MySQL控制器  
  2.   输入命令 “create

cheap downloadable software

  database   binary_data; ”  
  3.   输入命令 “use   binary_data; ”  
  输入如下命令:
   “CREATE   TABLE   binary_data   (   id   INT(4)   NOT   NULL   AUTO_INCREMENT   PRIMARY   KEY,description   CHAR(50),   bin_data   LONGBLOB,   filename   CHAR(50),   filesize   CHAR(50),   filetype   CHAR(50)); ”   (不能断行)  
  如果没有意外,数据库   和   表   应该建立好了。  
  三、一个怎样储存文件的例子程序  
  用这个例子你可以通过Html表单将文件传输到数据库中。  
  store.php3  
  //   store.php3   –   by   Florian   Dittmer  
  ?>  
  //   如果提交了表单,代码将被执行:  
  if   ($submit)   {  
  //   连接到数据库  
  //   (你可能需要调整主机名,用户名和密码)  
  MYSQL_CONNECT(   “localhost “,   “root “,   “password “);  
  MySQL_select_db(   “binary_data “);  
  $data   =   addslashes(fread(fopen($form_data,   “r “),   filesize($form_data)));  
  $result=MYSQL_QUERY(   “INSERT   INTO   binary_data   (description,bin_data,filename,filesize,filetype)VALUES   ( '$form_description ', '$data ', '$form_data_name ', '$form_data_size ', '$form_data_type ') “);  
  $id=   MySQL_insert_id();  
  print   “This   file   has   the   following   Database   ID:   $id “;  
  MYSQL_CLOSE();  
  }   else   {  
  //   否则显示储存新数据的表单  
  ?>  
   @MySQL_select_db(   “binary_data “);  
  $query   =   “select   bin_data,filetype   from   binary_data   where   id=$id “;  
  $result   =   @MYSQL_QUERY($query);  
  $data   =   @MYSQL_RESULT($result,0,   “bin_data “);  
  $type   =   @MYSQL_RESULT($result,0,   “filetype “);  
  Header(   “Content-type:   $type “);  
  echo   $data;  
  };  
  ?>  
程序必须知道要访问那个文件,   你必须将ID作为一个参数。  
  例如:   一个文件在数据库中的ID为2.   你可以这样调用它:   getdata.php3?id=2  
  如果你将图片储存在数据库里,   你可以向调用图片一样调用它。  
  Example:   一个图片文件在数据库中的ID为3.   你可以这样调用它:  
  五、怎样储存大于1MB的文件
  如果你想储存大于1MB的文件,你必须对你的程序、PHP设置、SQL设置进行许多修改。  
  下面几条也许可以帮助你储存小于24MB的文件:  
  1)   修改   store.php3,将   MAX_FILE_SIZE   的值改成   24000000。  
  2)   修改你的PHP设置,在一般情况下,PHP只允许小于2MB的文件,你必须将max_filesize(在php.ini中)的值改成24000000  
  3)   去掉MYSQL的数据包大小限制,在一般情况下   MYSQL   小于1   MB的数据包。
  4)   你必须用以下参数重启你的MYSQL   :/usr/local/bin/safe_MySQLd   -O   key_buffer=16M   -O   table_cache=128   -O   sort_buffer=4M   -O   record_buffer=1M   -O   max_allowed_packet=24M  
  5)   如果仍然出错:可能是超时错误,如果你通过一个很慢的连接来储存一个很大的文件,PHP缺省的时间限制为30秒。你可以将max_execution_time(在php.ini中)的值改为-1   。

zp8497586rq
赞(0)
未经允许不得转载:服务器VPS折腾 » MySQL存储二进制的数据,比如说图片文件