java将图片存入数据库

本文介绍了使用Java将图片文件转换为字节数组,并通过SQL语句将这些字节数组存储到数据库中的一种方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java将图片存入数据库

  (2013-01-15 19:48:47)
标签: 

it

分类: java
import java.sql.*;
import java.io.*;
import java.nio.*;

public class UploadImage {
       protected Connection dbConnection;
       protected String driverName = "com.mysql.jdbc.Driver";
       protected String dbURL = "jdbc:mysql://localhost/sample_db";
       protected String userID = "root";
       protected String passwd = "111111";

       public boolean storeImage(String sqlstr, File file) {
              try {
                     FileInputStream fin = new FileInputStream(file);
                     ByteBuffer nbf = ByteBuffer.allocate((int) file.length());
                     byte[] array = new byte[1024];
                     int offset = 0, length = 0;
                     while ((length = fin.read(array)) > 0) {
                            if (length != 1024)
                                   nbf.put(array, 0, length);
                            else
                                   nbf.put(array);
                            offset += length;
                     }
                     fin.close();
                     byte[] content = nbf.array();
                     return setImage(sqlstr, content);

              } catch (FileNotFoundException e) {
                     e.printStackTrace();
              } catch (IOException e) {
                     e.printStackTrace();
              }
              return false;
       }

       private boolean setImage(String sqlstr, byte[] in) {
              boolean flag = false;
              if (sqlstr == null)
                     sqlstr = "select * from picture_db";
              try {
                     Class.forName(driverName);
                     dbConnection = DriverManager.getConnection(dbURL, userID, passwd);
                     Statement stmt = dbConnection.createStatement(
                                   ResultSet.TYPE_SCROLL_INSENSITIVE,
                                   ResultSet.CONCUR_UPDATABLE);
                     ResultSet rs = stmt.executeQuery(sqlstr);
                     if (rs.next()) {
                            rs.updateBytes(2, in);
                            rs.updateRow();
                     } else {
                            rs.moveToInsertRow();
                            rs.updateString(1, "lena");
                            rs.updateBytes(2, in);
                            rs.insertRow();
                     }
                     rs.close();
                     flag = true;
              } catch (Exception e) {
                     e.printStackTrace();
              }
              return flag;
       }  

       public static void main(String[] args) {
              UploadImage upload = new UploadImage();
              try {
                     File file = new File("/home/dz/workspace/lena.jpg");
                     if (upload.storeImage(null, file))
                            System.out.print("true");
                     else
                            System.out.print("False");
              } catch (Exception e) {
                     e.printStackTrace();
              }
       }
}
### Java 将数组存入数据库的方法 为了将数组存入数据库,可以采用多种方式来处理不同类型的数组。一种常见的方式是利用JSON格式保存复杂结构的数据,比如二维数组中的学生信息和成绩。 #### 使用 JSON 存储多维数组 当涉及到存储像班级信息以及学生成绩这样的复合数据时,推荐使用`FastjsonTypeHandler`或其他类似的处理器将这些数据序列化为JSON字符串再存入数据库表中特定字段内[^3]。下面是一个简单的例子展示如何定义一个包含列表属性的实体类: ```java @Table(name="class_info") public class ClassInfo { @Id private Integer id; // 放入数据库解析成 json @Column(columnDefinition = "TEXT") @Convert(converter=JsonConverter.class) private List<List<Integer>> scores; // getter and setter methods... } ``` 这里假设`scores`代表各学生的分数情况,即内部List存放单个学生的多个科目得分;外部List则对应整个班的学生记录集合。 #### 用户输入与预处理 考虑到用户可能需要动态提供部分数据(如上述提到的成绩),可以通过`Scanner`获取终端用户的即时反馈并构建相应的Java对象实例[^1]。例如: ```java import java.util.ArrayList; import java.util.List; import java.util.Scanner; ... Scanner scanner = new Scanner(System.in); System.out.println("请输入学生数量:"); int numStudents = scanner.nextInt(); scanner.nextLine(); // Consume newline left-over List<List<Integer>> allScores = new ArrayList<>(); for (int i = 0; i < numStudents; ++i){ System.out.printf("第%d位同学的成绩:", i+1); String[] scoreStrs = scanner.nextLine().split(","); List<Integer> oneStudentScores = Arrays.stream(scoreStrs).map(Integer::parseInt).collect(Collectors.toList()); allScores.add(oneStudentScores); } ClassInfo ci = new ClassInfo(); ci.setScores(allScores); // Save to DB using MyBatis or other ORM frameworks. ``` 这段代码展示了怎样读取来自控制台的标准输入流,并将其转换为目标形式以便后续操作——无论是直接写入文件还是作为参数传递给持久层接口完成入库动作。 #### 批量插入优化 如果面对大量数据,则应该考虑效率更高的批量加载策略而不是逐条提交事务。借助于MyBatis Plus等框架提供的特性能够简化这一过程[^4]。通常情况下会先收集待更新/新增的数据项至内存缓冲区,达到一定规模后再统一执行SQL语句以减少网络开销及锁定时间。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值