两种,一种是将转化成二进制数据流存入数据库中。一种是保存的路径,然后前台读取路径去调用。相关的代码百度一下应该会有,第二种方法实现上比较简单,就是存储路径,然后根据路径读取对应的显示出来。第一种就比较麻烦,要先把转化成二进制数据,读取时就是从数据库读取对应数据再转化成显示出来。
两种,一种是将转化成二进制数据流存入数据库中。一种是保存的路径,然后前台读取路径去调用。相关的代码百度一下应该会有,第二种方法实现上比较简单,就是存储路径,然后根据路径读取对应的显示出来。第一种就比较麻烦,要先把转化成二进制数据,读取时就是从数据库读取对应数据再转化成显示出来。
1、使用blob将保存为二进制格式,(可以用浏览器来转换)随后用base64编码来保存,再将base64编码保存进数据库的clob类型字段上。
2、然后要用一个数据名称SystemDataOracleClient。
3、创建一个储存文件,然后把相关代码写入比如string execSql="insert into clob_table(clob_id,) values(1,:clob_pic);"编写代码的时候注意,后缀的符号(;")也要写入,不然无法进行下一步指令。
4、之前上面用的是base64编码,当显示的时候要将输出到浏览器流中,不然在base64里面是看不到。
5、在输出的时候要把转换成二进制(buffur即二进制编码)。
6、随后上传即可,然二进制流也可以存成文件(File)存到FTP服务器,当需要的时候可以根据路径进行下载的。
解决方法一般有两种:
1、将保存的路径存储到数据库;
2、将以二进制数据流的形式直接写入数据库字段中。
以下为具体方法:
一、保存的上传路径到数据库:
string
uppath="";//用于保存上传路径
//获取上传的文件名
string fileFullname =
thisFileUpload1FileName;
//获取上传的时间,以时间作为的名字可以防止重名
string
dataName =
DateTimeNowToString("yyyyMMddhhmmss");
//获取的文件名(不含扩展名)
string
fileName = fileFullnameSubstring(fileFullnameLastIndexOf("\\") +
1);
//获取扩展名
string type =
fileFullnameSubstring(fileFullnameLastIndexOf("") +
1);
//判断是否为要求的格式
if (type == "bmp" || type == "jpg" || type == "jpeg"
|| type == "gif" || type == "JPG" || type == "JPEG" || type == "BMP" || type ==
"GIF")
{
//将上传到指定路径的文件夹
thisFileUpload1SaveAs(ServerMapPath("~/upload")
+ "\\" + dataName + "" +
type);
//将路径保存到变量,将该变量的值保存到数据库相应字段即可
uppath
= "~/upload/" + dataName + "" +
type;
}
二、将以二进制数据流直接保存到数据库:
引用如下命名空间:
using
SystemDrawing;
using SystemIO;
using
SystemDataSqlClient;
设计数据库时,表中相应的字段类型为iamge
保存:
//路径
string
strPath = thisFileUpload1PostedFileFileNameToString
();
//读取
FileStream fs = new SystemIOFileStream(strPath,
FileModeOpen, FileAccessRead);
BinaryReader br = new
BinaryReader(fs);
byte[] photo =
brReadBytes((int)fsLength);
brClose();
fsClose();
//存入
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);
myCommParametersAdd("@photoBinary", SqlDbTypeBinary,
photoLength);
myCommParameters["@photoBinary"]Value =
photo;
myConnOpen();
if (myCommExecuteNonQuery() >
0)
{
thisLabel1Text =
"ok";
}
myConnClose();
读取:
连接数据库字符串省略
myconOpen();
SqlCommand
command = new
SqlCommand("select stuimage from stuInfo where stuid=107",
mycon);//查询语句根据需要修改
byte[] image = (byte[])commandExecuteScalar
();
//指定从数据库读取出来的的保存路径及名字
string strPath =
"~/Upload/zhangsanJPG";
string strPhotoPath =
ServerMapPath(strPath);
//按上面的路径与名字保存文件
BinaryWriter bw = new
BinaryWriter(FileOpen(strPhotoPath,FileModeOpenOrCreate));
bwWrite(image);
bwClose();
//显示
thisImage1ImageUrl
= strPath;
采用这两种方式可以根据实际需求灵活选择。
一般都是这样的,就是在你服务器有一个专门放置的文件夹,然后数据库保存的是你服务器的路径。需要用的时候就去数据库里面取路径。得到路径以后你想怎么处理是你的事情了。
至于如何去数据库取路径这个就是简单的db *** 作。
加载驱动类:
ClassforName(DBDriver);
获取连接:
Connection conn = DriverManagergetConnection(url,username,password);
创建 *** 作对象:
PreparedStatement stmt = conprepareStatement(sql);
执行 *** 作:
ResultSet rs = stmtexecuteQuery();
遍历结果:
List list = new ArrayList();
while(rsnext()){
//具体 *** 作,通常用rsgetString(name)取值
Image img = new Image();//类对应你数据库中表格
imgsetSrc(rsgetString("src"));//假设你数据库中image表中地址字段是src
listadd(img);
}
记得关闭资源:
rsclose();
stmtclose();
conclose();
看你的意思是已经取出来了不知道怎么显示:
你取出来之后可以把放在一个list里面然后去页面上遍历这个list
<c:forEach var="chakan1" items="list">
<tr>
<td>
<img src="${chakan1src}"/>
</td>
</tr>
</c:forEach>
大致应该是这样
以上就是关于数据库中怎么存放图片全部的内容,包括:数据库中怎么存放图片、如何往数据库中存图片、图片如何存放在oracle数据库等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)