图怎么保存在mysql 图画保存的图片在哪

mysql里怎么存放图片

你好,很高兴回答你的问题。

创新互联-专业网站定制、快速模板网站建设、高性价比瓮安网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式瓮安网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖瓮安地区。费用合理售后完善,10余年实体公司更值得信赖。

一般有两种方式,

一种是将图片序列化后,将序列化的结果存入数据库中。使用时在读出进行反序列化。

另一种是将文件存放到一个位置,将存放的路径存入数据库。使用时按照路径获取图片。

如果有帮助到你,请点击采纳。

如何将图片储存在MySQL数据库里

通常对用户上传的图片需要保存到数据库中。解决方法一般有两种:一种是将图片保存的路径存储到数据库;另一种是将图片以二进制数据流的形式直接写入数据库字段中。以下为具体方法:

一、保存图片的上传路径到数据库:

string uppath="";//用于保存图片上传路径

//获取上传图片的文件名

string fileFullname = this.FileUpload1.FileName;

//获取图片上传的时间,以时间作为图片的名字可以防止图片重名

string dataName = DateTime.Now.ToString("yyyyMMddhhmmss");

//获取图片的文件名(不含扩展名)

string fileName = fileFullname.Substring(fileFullname.LastIndexOf("\\") + 1);

//获取图片扩展名

string type = fileFullname.Substring(fileFullname.LastIndexOf(".") + 1);

//判断是否为要求的格式

if (type == "bmp" || type == "jpg" || type == "jpeg" || type == "gif" || type == "JPG" || type == "JPEG" || type == "BMP" || type == "GIF")

{

//将图片上传到指定路径的文件夹

this.FileUpload1.SaveAs(Server.MapPath("~/upload") + "\\" + dataName + "." + type);

//将路径保存到变量,将该变量的值保存到数据库相应字段即可

uppath = "~/upload/" + dataName + "." + type;

}

二、将图片以二进制数据流直接保存到数据库:

引用如下命名空间:

using System.Drawing;

using System.IO;

using System.Data.SqlClient;

设计数据库时,表中相应的字段类型为iamge

保存:

//图片路径

string strPath = this.FileUpload1.PostedFile.FileName.ToString ();

//读取图片

FileStream fs = new System.IO.FileStream(strPath, FileMode.Open, FileAccess.Read);

BinaryReader br = new BinaryReader(fs);

byte[] photo = br.ReadBytes((int)fs.Length);

br.Close();

fs.Close();

//存入

SqlConnection myConn = new SqlConnection("Data Source=.;Initial Catalog=stumanage;User ID=sa;Password=123");

string strComm = " INSERT INTO stuInfo(stuid,stuimage) VALUES(107,@photoBinary )";//操作数据库语句根据需要修改

SqlCommand myComm = new SqlCommand(strComm, myConn);

myComm.Parameters.Add("@photoBinary", SqlDbType.Binary, photo.Length);

myComm.Parameters["@photoBinary"].Value = photo;

myConn.Open();

if (myComm.ExecuteNonQuery() 0)

{

this.Label1.Text = "ok";

}

myConn.Close();

读取:

...连接数据库字符串省略

mycon.Open();

SqlCommand command = new

SqlCommand("select stuimage from stuInfo where stuid=107", mycon);//查询语句根据需要修改

byte[] image = (byte[])command.ExecuteScalar ();

//指定从数据库读取出来的图片的保存路径及名字

string strPath = "~/Upload/zhangsan.JPG";

string strPhotoPath = Server.MapPath(strPath);

//按上面的路径与名字保存图片文件

BinaryWriter bw = new BinaryWriter(File.Open(strPhotoPath,FileMode.OpenOrCreate));

bw.Write(image);

bw.Close();

//显示图片

this.Image1.ImageUrl = strPath;

采用俩种方式可以根据实际需求灵活选择。

小技巧:怎样在 Mysql 中直接储存图片

如果你想把二进制的数据 比如说图片文件和HTML文件 直接保存在你的MySQL数据库 那么这篇文章就是为你而写的! 我将告诉你怎样通过HTML表单来储存这些文件 怎样访问和使用这些文件 本文概述 在mysql中建立一个新的数据库 一个怎样储存文件的例子程序 一个怎样访问文件的例子程序 在mysql中建立一个新的database 首先 你必须在你的mysql中建立一个新的数据库 我们将会把那些二进制文件储存在这个数据库里 在例子中我会使用下列结构 为了建立数据库 你必须做下列步骤 进入MySql控制器 输入命令 create database binary_data; 输入命令 use binary_data; 输入命令 CREATE TABLE binary_data ( id INT( ) NOT NULL AUTO_INCREMENT PRIMARY KEY description CHAR( ) bin_data LONGBLOB filename CHAR( ) filesize CHAR( ) filetype CHAR( )); (不能断行) 如果没有意外 数据库 和 表 应该建立好了 一个怎样储存文件的例子程序 用这个例子你可以通过Html表单将文件传输到数据库中 store php ?php // store php by Florian Dittmer ? HTML HEADTITLEStore binary data into SQL Database/TITLE/HEAD BODY ?php // 如果提交了表单 代码将被执行: 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 pThis file has the following Database ID: b$id/b ; MYSQL_CLOSE(); } else { // 否则显示储存新数据的表单 ? form method= post action= ?php echo $PHP_SELF; ? enctype= multipart/form data File Description:br input type= text name= form_description size= INPUT TYPE= hidden name= MAX_FILE_SIZE value= brFile to upload/store in database:br input type= file name= form_data size= pinput type= submit name= submit value= submit /form ?php } ? /BODY /HTML 如果你执行了这个程序 你将会看见一个简单的Html表单 单击 浏览 选择一个文件 然后单击提交 当文件上传至web服务器之后 程序将会告诉你刚刚上传的文件的ID 记住这个ID 待会要用的 一个怎样访问文件的例子程序 你可以通过这个程序访问你刚才储存的文件 ?php // getdata php by Florian Dittmer // 调用方法: getdata php ?id=id if($id) { // 你可能需要调整主机名 用户名和密码: @MYSQL_CONNECT( localhost root password ); @mysql_select_db( binary_data ); $query = select bin_data filetype from binary_data where id=$id ; $result = @MYSQL_QUERY($query); $data = @MYSQL_RESULT($result bin_data ); $type = @MYSQL_RESULT($result filetype ); Header( Content type: $type ); echo $data; }; ? 程序必须知道要访问那个文件 你必须将ID作为一个参数 例如: 一个文件在数据库中的ID为 你可以这样调用它: getdata php ?id= 如果你将图片储存在数据库里 你可以向调用图片一样调用它 Example: 一个图片文件在数据库中的ID为 你可以这样调用它: img src= getdata php ?id= 怎样储存大于 MB的文件: 如果你想储存大于 MB的文件 你必须对你的程序 PHP设置 SQL设置进行许多修改 下面几条也许可以帮助你储存小于 MB的文件 修改 store php 将 MAX_FILE_SIZE 的值改成 修改你的PHP设置 在一般情况下 PHP只允许小于 MB的文件 你必须将max_filesize(在php ini中)的值改成 去掉MYSQL的数据包大小限制 在一般情况下 MYSQL 小于 MB的数据包 你必须用以下参数重启你的MYSQL /usr/local/bin/safe_mysqld O key_buffer= M O table_cache= O sort_buffer= M O record_buffer= M O max_allowed_packet= M 如果仍然出错 可能是超时错误 如果你通过一个很慢的连接来储存一个很大的文件 PHP缺省的时间限制为 秒 你可以将max_execution_time(在php ini中)的值改为 lishixinzhi/Article/program/MySQL/201311/29424

如何将图片储存在MySQL数据库中

1 图片文件 存储在磁盘 数据库存储磁盘的路径(字符串).

2 把图片文件序列化转成一个字符串 存储。

3 直接把图片文件存储到 大二进制字段里面。


分享标题:图怎么保存在mysql 图画保存的图片在哪
URL链接:http://scjbc.cn/article/doceigj.html

其他资讯