当前位置:首页 » 存储配置 » 数据库可以存储图片吗

数据库可以存储图片吗

发布时间: 2024-11-24 08:33:55

‘壹’ Mysql是否支持存储和处理图片mysql不支持图片吗

MySQL数据库是一种关系型数据库管理系统,广泛应用于网站、应用程序和企业级应用程序等各种领域。随着互联网上图片和视频等多媒体内容的爆发式增长,许多人都在提出一个问题:MySQL是否支持存储和处理图片?在本文中,我们将探讨MySQL对图片的存储和处理的能力。
MySQL是否能存储图片?
MySQL本身虽然没有专门设计来存储图片的数据类型,但可以通过BLOB数据类型存储二进制数据,包括图片、声音和视频…等文件。其中,BLOB数据类型是一种二进制大对象类型,它可以存储大量的二进制数据,最大存储尺寸是64KB,如果需要存储更大的数据,可设置为MEDIUMBLOB或LONGBLOB数据类型。BLOB数据类型特点如下:
1. 二进制存储
2. 数据长度不限
3. 获得、插入和更新需要使用二进制函数
那么,如何将图片存储到MySQL中?我们可以通过以下示例代码实现:
$img = file_get_contents(“test.png”);//获取图片
$mysqli = new mysqli(‘localhost’,’root’,’root’,’test’);//连接数据库
$sql = “INSERT INTO images(img) VALUES(‘$img’)”;//插入数据到数据库中
$mysqli->query($sql);//执行SQL语句
echo($mysqli->error);//输出错误信息
?>
上述代码将会读取名为test.png的图片文件,并将其存储到名为images的MySQL表中。这样,我们就实现了将图片存储到MySQL中的操作。
MySQL是否能处理图片?
MySQL本身虽然不支持直接处理图片,但应用程序可以通过使用图片处理库来实现自己的图片处理功能。我们可以基于PHP GD库、ImageMagick等等来实现图片处理,如生成缩略图、添加水印、裁剪图片等等。
我们以图片缩略图的生成为例,介绍如何实现图片处理。以下为示例代码:
$img = file_get_contents(“test.png”);//获取图片
$mysqli = new mysqli(‘localhost’,’root’,’root’,’test’);//连接数据库
$sql = “SELECT * FROM images”;//查询数据
$result = $mysqli->query($sql);//执行SQL语句
$row = $result->fetch_assoc();//获取查询结果
$img = imagecreatefromstring($row[‘img’]);//生成图片
$tmb = imagecreatetruecolor(100,100);//生成缩略图
imageresampled($tmb,$img,0,0,0,0,100,100,imagesx($img),imagesy($img));//拷贝并缩放图像
header(‘Content-Type: image/jpeg’);//设置输出格式为JPEG
imagejpeg($tmb);//输出图像
?>
上述代码通过查询images表中的img字段获取到图片数据,然后基于PHP中提供的GD库来生成一个100×100像素的缩略图,并在输出头(header)中设置图像类型为JPEG,并输出图像。
结论
MySQL数据库本身无法处理和存储图片,但我们可以通过其BLOB数据类型存储图片的二进制数据,并通过应用程序的图片处理库来实现图片处理功能。建议在应用程序中不要滥用大型二进制数据类型,尽可能地将多媒体文件保存在文件系统中,并在MySQL中存储其相关信息和路径,以尽可能地提高系统的性能和可维护性。

‘贰’ 数据库中可以存储照片么怎么存储

数据中可以存储图片,但是需要注意不能直接存储图片,而是转换成二进制或者Base64等的“文本”来存储,在用的时候,可以再转换回来。
在网站开发中,一般将图片存储在文件系统中,而不是数据系统中,数据库系统中只记录图片在文件系统中的路径而已。

‘叁’ 数据库能存图片吗

问题一:数据库怎样可以将图片放到里面 首先肯定一点,数据库中是可以放图片数据的!但是这样的话,数据体积会很庞大,当然最好还是把图片放到文件夹中,数据只用来存放图片路径,不过最好是存放相对路径,应该以后可能设计到图片单独放在另一台服务器上,或换了文件夹。

问题二:SQL数据库中能存照片吗? 图片完全可以存放,但是在数据库中不能以select * from a进行查询
但是在相对应得c#、java中可以查询
是以二进制保存的。

数据库,只要是抽象出来的数据,都可以保存。
而已不能保存的,就是实体,像处啊、鞋子啊、男朋友啊都不姓

问题三:mysql数据库可以存图片吗? 可以。存图片的列需要设置成BLOB、MEDIUMBLOB或LONGBLOB等数据类型。
但是以前基本上不会把图片直接存在数据库里,因为数据库里的数据是为了用来快速分析、快速存取的,图片数据在mysql里既不能建立索引也不能和其他数据一起分析,存取速度和读写磁盘也没什么区别,每次备份、导入导出数据库时还增加了数据量,降低了效率。所以一般都是把图片存在系统里,然后把图片的存放路径放在数据库里。

问题四:图片如何存入数据库 第一种方式:保存图片路径至数据库中
第二种方式:数据插入相应表中,参数类型为byte[]
例如:
sql:insert into table(imageColumn) values (@image);
其中@image参数值为byte[]类型的变量

问题五:图片如何存放在oracle数据库 测试可行。这只是核心Class文件代码,你要是弄不出来,就再联系我,我再把整个项目给你。这是把图片真个放到数据库
package .;
import java.io.FileInputStream;
import java.io.OutputStream;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Scanner;
import oracle.sql.BLOB;
public class Insert {
Scanner sc =new Scanner(System.in);
@SuppressWarnings(deprecation)
public int insertbinary(String pname,String src1){
Connection con = null;
String sql = insert into test values(?,?);
String sql1 =update test set image=? where pname=?;
int res = 0;
try {
con=BaseDAO.getConnection();
con.setAutomit(false);
PreparedStatement pstm = con.prepareStatement(sql);
pstm.setString(1, pname);
EMPTY_BLOB和EMPTY_CLOB返回一个空的LOB定位器,
可以用来初始化一个LOB变量,或在INSERT或UPDATE语句,
初始化LOB列或属性为空。 EMPTY表示LOB初始化,但不填充数据。
pstm.setBlob(2, oracle.sql.BLOB.empty_lob());
pstm.executeUpdate();
pstm.close();
pstm = con.prepareStatement(select * from test where pname=?);
pstm.setString(1, pname);
ResultSet rs = pstm.executeQuery();
rs.next();
BLOB blob = (BLOB) rs.getBlob(2);
OutputStream os = blob.getBinaryOutputStream();
FileInputStream fi = new FileInputStream(src1);
byte[] buff = new byte[1024];
int len = fi.read(buff);
while (len != -1) {
os.write(buff);
len = fi.read(buff);
}
pstm = con.prepareStatement(sql1);
pstm.setBlob(1,......>>

问题六:如何将图片储存在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......>>

问题七:如何在数据库中存储图片文件 解决方法一般有两种:
一种是将图片保存的路径存储到数据库;
另一种是将图片以二进制数据流的形式直接写入数据库字段中。

问题八:如何将图片存到数据库 通常对用户上传的图片需要保存到数据库中。解决方法一般有两种:一种是将图片保存的路径存储到数据库;另一种是将图片以二进制数据流的形式直接写入数据库字段中。以下为具体方法:
一、保存图片的上传路径到数据库:
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......>>

问题九:怎样数据库access保存jpg图片 只有两种方法
1.存图片地址,图片放服务器的一个文件夹里
2.存图片的数据,也就是二进制流
既然第一种你说不行 那只能第二种了。
我只说一下思路,代码网上找一下,多的很,也不麻烦1.数据库字段类型为image(sqlserver的是image,不知道access的是不是)
2.把图片文件序列化 放到一个byte[]数组里,然后存到数据库
显示的时候:
1.单独在一个页面读出图片的内容到一个byte[]数组
2.用response把这段二进制输出
3.在要引用的地方,比如你的image控件,把引用的地址指向这个页面就行了

问题十:如何像数据库中保存图片? 一般图像是不保存在数据库的.而是先将图片放在工程下的某个文件夹中,将图片所在的工程文件路径存在数据库中,当程序加载图片的时候,从数据库中读取图片的路径,然后根据路径在工程的文件夹中读取图片文件

热点内容
数据库缩略 发布:2024-11-24 10:54:18 浏览:597
uniqidphp 发布:2024-11-24 10:54:15 浏览:658
linux设备驱动程序pdf 发布:2024-11-24 10:40:26 浏览:804
金盾pdf加密提取 发布:2024-11-24 10:37:01 浏览:809
sqlserver2005报表 发布:2024-11-24 10:33:23 浏览:584
直男Qq密码一般会设成什么 发布:2024-11-24 10:28:00 浏览:198
苹果怎么传照片蓝牙到安卓 发布:2024-11-24 10:21:04 浏览:856
比亚迪秦值得买哪个配置 发布:2024-11-24 10:20:23 浏览:73
河北智慧网关服务器云服务器 发布:2024-11-24 10:20:22 浏览:761
linux启动服务命令 发布:2024-11-24 10:15:25 浏览:703