首页数据库数据库如何存储图片(如何在sql server中存储图片)

数据库如何存储图片(如何在sql server中存储图片)

编程之家2023-10-22280次浏览

大家好,感谢邀请,今天来为大家分享一下数据库如何存储图片的问题,以及和如何在sql server中存储图片的一些困惑,大家要是还不太明白的话,也没有关系,因为接下来将为大家分享,希望可以帮助到大家,解决大家的问题,下面就开始吧!

数据库如何存储图片(如何在sql server中存储图片)

如何在sql server中存储图片

1、首先可以存储图片链接,设置图片链接字段,如下图所示。

2、接着直接将图片的链接添加到SQL数据表的字段里即可,如下图所示。

3、或者用二进制存储图片字段,在SQL Server数据库中先制作成image字段。

4、接着在后台通过代码形式,将图片转化为二进制,如下图所示。

5、得到二进制数据后,则可通过sql语句插入到数据表中。

6、数据表即可存储了图片字段,将二进制转化为图片。

数据库如何存储图片(如何在sql server中存储图片)

数据库能存图片吗

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

问题二:SQL数据库中能存照片吗?图片完全可以存放,但是在数据库中不能以select* from a进行查询

但是在相对应得c#、Java中可以查询

是以二进制保存的。

数据库如何存储图片(如何在sql server中存储图片)

数据库,只要是抽象出来的数据,都可以保存。

而已不能保存的,就是实体,像处啊、鞋子啊、男朋友啊都不姓

问题三:mysql数据库可以存图片吗?可以。存图片的列需要设置成BLOB、MEDIUMBLOB或LONGBLOB等数据类型。

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

问题四:图片如何存入数据库第一种方式:保存图片路径至数据库中

第二种方式:数据插入相应表中,参数类型为byte[]

例如:

sql:insert into table(imageColumn) values(@image);

其中@image参数值为byte[]类型的变量

问题五:图片如何存放在oracle数据库测试可行。这只是核心Class文件代码,你要是弄不出来,就再联系我,我再把整个项目给你。这是把图片真个放到数据库

package.dao;

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控件,把引用的地址指向这个页面就行了

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

图片如何存入数据库

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

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

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;

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

关于本次数据库如何存储图片和如何在sql server中存储图片的问题分享到这里就结束了,如果解决了您的问题,我们非常高兴。

mysql数据库回滚(mysql命令行下怎样实现数据的回滚操作)mysql数据库分库分表 MySQL使用为什么要分库分表