如何使用数据库保存文件

    最近在做专业设计,好多同学讨论上传的文件应该以什么形式保存到数据库中

    对于这个问题,有两种解决方案

                一:将文件copy到项目下一个包中(这里设定的是在专业设计、SSH小项目中),数据库存储文件的路径

                二:数据库直接存储文件,比如一些小的图片,如几十K的头像图片等,可以直接转换成二进制,存放到数据库中

    第一种解决方案的实现,好多同行已经写了很详细的文章了,在这里放一个链接:

                https://blog.youkuaiyun.com/uniquewonderq/article/details/47057641

    对于第二种解决方案的实现,在这里记录并且分享一下:

                其实很简单,就是接受文件,将文件读取,转换成byte[],然后直接存储到数据库中,代码如下。

                假设封装类User有一个photo属性,用来存放头像信息。

                    读取上传的图片并进行封装:

                    InputStream in = new FileInputStream("c:/fugang.jpg");

                    byte[] photo = new byte[in.available()];

                    in.read(photo);                   

                    in.close();

                    User.setPhoto(photo);

                然后将其保存到数据库中就可以了,这里数据库的属性(拿mysql为例)为binary,并且要指定长度,因为binary在   数据库中有好几种保存长度,如果不指定,可能长度不够使用

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值