Java+mysql本地图片上传数据库及下载示例

作者:Ro_kin 时间:2023-07-23 19:49:13 

做一个将本地图片上传到mysql数据库的小实例,顺便也下载下来到桌面检测是否上传成功。

在写代码之前得先在数据库中建立image表,用来存储图片。


create table image
(id int primary key auto_increment ,
name varchar(30) COMMENT '名称',
content mediumblob COMMENT '图片');

下面直接上代码:


package jdbc_imagetest;

import java.io.*;
import java.sql.*;
/**
* 将本地文件的图片传到数据库的test的image表中并下载到本机桌面
*/
public class Test1 {

private static String url="jdbc:mysql://localhost:3306/test";
 private static String user="root";
 private static String password="123456";
 private static Connection con;

public static void main(String[] args) throws Exception {
   Class.forName("com.mysql.jdbc.Driver");
   con=DriverManager.getConnection(url,user,password);
   shangchuan();
   xiazai();    
 }
 //添加图片到数据库test4的file表
 public static void shangchuan() throws Exception{
   String sql="insert into image(name,content) values(?,?)";
   PreparedStatement ptmt=con.prepareStatement(sql);
   ptmt.setString(1, "美女.jpg");
   InputStream is=null;
   is=new FileInputStream("D:\\Pictures\\3.jpg");
   ptmt.setBinaryStream(2, is,is.available());
   //方法说明:PreparedStatement.setBinaryStream(int parameterIndex, InputStream x, int length)
   ptmt.execute();
   System.out.println("图片添加成功!");

}
 //从数据库中把图片下载至桌面
 public static void xiazai() throws Exception{
   String sql="select content from image where id=3";//在我这里3.jpg是第三张图片
   Statement stmt=con.createStatement();
   ResultSet rs=stmt.executeQuery(sql);//将查询结果给rs
   if(rs.next()){
     InputStream is=rs.getBinaryStream("fcontent");
     //.getBinaryStream():a Java input stream that delivers the database column value as a stream of uninterpreted bytes
     FileOutputStream fos=new FileOutputStream("C:\\Users\\Desktop\\美女.jpg");
     byte[] buffer=new byte[1024];
     int len=0;
     while((len=is.read(buffer))!=-1){
       fos.write(buffer,0,len);//将数据库的图片写出
     }
     System.out.println("下载成功!已下载至桌面,请查看");
   }else{
     System.out.println("图片不存在!");
   }
   con.close();
 }

}

测试成功

来源:http://blog.csdn.net/ro_kin/article/details/54705782

标签:java,上传文件
0
投稿

猜你喜欢

  • 快速解决pandas.read_csv()乱码的问题

    2023-07-10 21:14:47
  • MySQL MEM_ROOT详解及实例代码

    2024-01-15 13:42:54
  • MySQL 百万级分页优化(Mysql千万级快速分页)

    2024-01-22 02:43:26
  • MySQL学习笔记之数据定义表约束,分页方法总结

    2024-01-13 13:46:38
  • Python if else语句对缩进的要求

    2021-03-07 03:32:12
  • asp 自定义分段函数/求第N名成绩

    2011-03-25 11:07:00
  • bootstrap-table实现表头固定以及列固定的方法示例

    2024-04-29 13:13:19
  • Innodb中mysql快速删除2T的大表方法示例

    2024-01-22 09:14:21
  • 微信小程序简单的canvas裁剪图片功能详解

    2023-08-24 07:49:20
  • 使用pycharm和pylint检查python代码规范操作

    2023-06-06 08:02:38
  • asp实现的查询某关键词在MSSQL数据库位置的代码

    2011-02-28 11:18:00
  • Python格式化输出字符串方法小结【%与format】

    2023-01-06 00:01:50
  • Python中PyQt5/PySide2的按钮控件使用实例

    2023-03-04 16:27:44
  • MySQL命令无法输入中文问题的解决方式

    2024-01-15 19:29:54
  • Python实现以时间换空间的缓存替换算法

    2021-03-31 13:45:16
  • python 爬取百度文库并下载(免费文章限定)

    2022-05-08 16:18:28
  • 淘宝2011新版首页开发实践

    2011-01-20 20:07:00
  • Python locust工具使用详解

    2021-11-04 04:04:56
  • Python Websocket服务端通信的使用示例

    2021-09-16 15:03:19
  • MySQL实现批量插入以优化性能的教程

    2024-01-25 23:27:53
  • asp之家 网络编程 m.aspxhome.com