网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

怎么基于java向mysql数据库中存取图片

这篇文章将为大家详细讲解有关怎么基于java向MySQL数据库中存取图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

网站建设公司,为您提供网站建设,网站制作,网页设计及定制网站建设服务,专注于成都企业网站定制,高端网页制作,对成都不锈钢雕塑等多个行业拥有丰富的网站建设经验的网站建设公司。专业网站设计,网站优化推广哪家好,专业成都网站推广优化,H5建站,响应式网站。

学mysql的时候都是做个表格,放的也都是文字内容,虽然我知道长篇的文章和图片或者视频的都是用过文件夹的方式存储的,再讲文件路径存进数据库中。但还是想试试直接往mysql数据库中存取图片。这里我用的是java语言和jdbc实现的

mysql数据库中有一个类型是Blob类型,这是一个二进制类型,通常我们会将图片或音像文件转成二进制再存入数据库中,Blob分为以下几种:

TinyBlob 最大 255  Blob 最大 65K  MediumBlob 最大 16M  LongBlob 最大 4G

除了jdbc的连接以外,我们需要用到文件的输入、输出流。实现两个方法,一个方法向数据库中存图像,另一个方法从数据库中读取图像并存在电脑本地

import java.io.*;
import java.sql.*;
import java.sql.DriverManager;
import java.sql.ResultSet;import java.sql.SQLException;
import java.util.Scanner;
public class Database {  //JDBC驱动名  
String JDBC_DRIVER = "com.mysql.jdbc.Driver";  //数据库URL:这里的tt是数据库名称  
String JDBC_URL = "jdbc:mysql://localhost:3306/daImage?useSSL=false&serverTimezone=UTC";  //    数据库的用户名与密码  
String USER = "root";  String PASS = "admin123";  //通过DriverManager类获得该连接对象才能访问数据库  
Connection connection = null;  //    通过Connection获得该结果对象用于执行静态的SQL语句//  
Statement statement = null;  PreparedStatement preparedStatement = null;  String path;  
FileInputStream fileInputStream;    Database() {//      注册JDBC驱动    try {      
Class.forName(JDBC_DRIVER);//      数据库的连接:通过DriverManager类的getConnection方法,传入三个参数:数据库URL、用户名、用户密码,实例化connection对象      
connection = DriverManager.getConnection(JDBC_URL, USER, PASS);    } catch (ClassNotFoundException e) {      
e.printStackTrace();    
} catch (SQLException e) {      
e.printStackTrace();    
}  
}  
public void add(){    //      定义数据库查询语句:查询aa表中的name、sex两列数据    
String sql = "insert into taImage values(?,?,?) ";//    读取图片,图片放在电脑本地,所以我这里手动复制了路径    
File file = new File("/Users/liuliu/Desktop/vv.jpeg");    try {      
FileInputStream fi = new FileInputStream(file);      preparedStatement = connection.prepareStatement(sql);      
preparedStatement.setInt(1, 2);      preparedStatement.setString(2, "图片一");      
preparedStatement.setBlob(3, fi);//      执行查询语句      
int f = preparedStatement.executeUpdate();      
if (f > 0) {        
System.out.println("插入成功");      
} 
else {        System.out.println("插入失败");      
}      
preparedStatement.close();      
connection.close();    
} catch (SQLException e) {      
e.printStackTrace();    } 
catch (FileNotFoundException e) {      
e.printStackTrace();    }  }  
public void select() {    
Blob get_image;    
String sql = "select* from taImage";    
try {//      将读取到的图片存放到指定的路径中      
FileOutputStream fileOutputStream = new FileOutputStream("/Users/liuliu/Desktop/bb.jpg");      
preparedStatement = connection.prepareStatement(sql);      
ResultSet resultSet = preparedStatement.executeQuery();      
while (resultSet.next()) {        
get_image = resultSet.getBlob("photo");//        将读取到的Blob对象转成字节流        
inputStream = get_image.getBinaryStream();        
int a;        byte b[] = new byte[1014];        
while ((a = inputStream.read(b)) != -1) {          
fileOutputStream.write(b, 0, a);        
}      }    } catch (SQLException e) {      
e.printStackTrace();    } catch (FileNotFoundException e) {      
e.printStackTrace();    } catch (IOException e) {      
e.printStackTrace();    }  
}
}

关于“怎么基于java向mysql数据库中存取图片”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


本文名称:怎么基于java向mysql数据库中存取图片
文章出自:http://bjjierui.cn/article/gdggsg.html

其他资讯