java 解析读取mdb数据 jackcess篇

1 篇文章 0 订阅
1 篇文章 0 订阅

pom文件添加jackcess依赖

		<dependency>
			<groupId>com.healthmarketscience.jackcess</groupId>
			<artifactId>jackcess</artifactId>
			<version>3.0.1</version>
		</dependency>

创建AccessJackcessUtils工具类,粘贴内容

这里首先要说下,.mdb文件实际上是个库,,类似于mysql里面一个库,库里面也会有多个表的。

package com.uniwill.data.tools;

import com.healthmarketscience.jackcess.Database;
import com.healthmarketscience.jackcess.DatabaseBuilder;
import com.healthmarketscience.jackcess.Table;
import lombok.extern.slf4j.Slf4j;

import java.io.File;
import java.io.IOException;
import java.nio.charset.Charset;
import java.util.*;

/**
 * @Author: tianxubo
 * @CreateTime: 2022-10-18 16:05:40
 * @Description: Jackcess
 */
@Slf4j
public class AccessJackcessUtils {

    public static void main(String[] args) {

        String filePath = "C:\\Users\\txb\\Desktop\\445103SXB.mdb";
        //先创建整个库对应的对象集合 maps[key:表名 value :key表数据集合]; Map<String,Object> 表示一行数据
        Map<String, List<Map<String, Object>>> maps = readFileAccessTables(filePath);   //获取这个库全部数据
    }

    /**
     * 读取mdb全部表格和数据
     *
     * @param filePath 文件路径
     */
    public static Map<String, List<Map<String, Object>>> readFileAccessTables(String filePath) {
        //Map<String,List<Map<String,Object>>> key:表名 value :数据集合
        Map<String, List<Map<String, Object>>> maps = new HashMap<>();
        File file = new File(filePath);
        if (!file.exists()) {
            throw new RuntimeException("mdb文件不存在[" + filePath + "]");
        }
        try {
            Database db = DatabaseBuilder.open(new File(filePath));
            if (null == db) {
                throw new RuntimeException("无法读取mdb文件[" + filePath + "]");
            }
            Set<String> tableSet = db.getTableNames();
            if (tableSet.size() < 1) {
                throw new RuntimeException("[" + filePath + "]库中不存在表格");
            }
            Charset charSet = db.getCharset();
            if (null == charSet) {
                throw new RuntimeException("[" + filePath + "]库中字符集编码不存在");
            }
            log.debug("字符集:" + charSet.name());
            for (String tableName : tableSet) {
                Table table = db.getTable(tableName);
                List<Map<String, Object>> tableData = new ArrayList<>();
                for (Map<String, Object> rowData : table) {
                    tableData.add(rowData);
                }
                log.debug("表名:" + tableName + ",数据" + tableData.size() + "行");
                maps.put(tableName, tableData);
            }
            db.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return maps;
    }

    /**
     * 读取mdb库中某表数据
     *
     * @param filePath 文件路径
     * @param tableName 表名
     */
    public static List<Map<String, Object>> readFileAccessTable(String filePath, String tableName) {
        //表数据集合
        List<Map<String, Object>> result = new ArrayList<>();
        File file = new File(filePath);
        Database db = null;
        try {
            if (!file.exists()) {
                throw new RuntimeException("mdb文件不存在[" + filePath + "]");
            }
            DatabaseBuilder.open(new File(filePath));
            if (null == db) {
                throw new RuntimeException("无法读取mdb文件[" + filePath + "]");
            }
            Set<String> tableSet = db.getTableNames();
            if (tableSet.size() < 1) {
                throw new RuntimeException("[" + filePath + "]库中不存在表格");
            }
            Charset charSet = db.getCharset();
            if (null == charSet) {
                throw new RuntimeException("[" + filePath + "]库中字符集编码不存在");
            }
            log.debug("字符集:" + charSet.name());

            Table table = db.getTable(tableName);
            for (Map<String, Object> rowData : table) {
                result.add(rowData);
            }
            log.debug("表名:" + tableName + ",数据" + result.size() + "行");

        } catch (IOException e) {
            e.printStackTrace();
        }
        return result;
    }
}

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 15
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值