Java解析MDB(上)-纯JDBC解析非空间数据

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 本文讲解了在java中使用jdbc的方式来解析非空间mdb数据,并给出了具体的关键代码​,包括动态获取mdb的表名,通过表名获取字段名和属性值。​希望对你有帮助。

      MDB格式数据可以用来存储空间信息,也可以用来存储非空间信息。如果用来存储非空间数据的话,跟普通的excel表格及关系型数据库是一样的。您可以使用微软的access数据库直接打开,也可以使用arcgis、或者qgis的地理编辑软件打开。

     本文将使用JDBC的方式来讲解如何解析非空间MDB数据,将自动获取表表名和字段名。本例采用arcmap软件打开目标文件。可以看到mdb文件的内容如下:image.png

    以上表示该数据不包含空间信息,仅包含属性表信息。

image.png

表里面的字段信息如下:

image.png

   在Java中如何获取到解析这些数据呢?下面教你具体如何来解析。

一、既然要使用jdbc的方式,就要在pom.xml中定义相关依赖

<dependency><groupId>net.sf.ucanaccess</groupId><artifactId>ucanaccess</artifactId><version>4.0.4</version></dependency>

二、动态从mdb文件中获取所有的表名,关键代码如下:

@TestpublicvoidgetAllTables() {
try {
Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");
StringaccessDb="F:/vector_data/other/gdal_demo_data/mdb-data/2015phone/20150210mobile.mdb";
StringdbURL="jdbc:ucanaccess://"+accessDb;
Connectionconn=DriverManager.getConnection(dbURL);
System.out.println(conn);
DatabaseMetaDatametadata=conn.getMetaData();
ResultSettables=metadata.getTables(null, null, "%", null);
while (tables.next()) {
System.out.println(tables.getString(3));
            }
tables.close();
conn.close();
        }catch (Exceptione) {
e.printStackTrace();
        }
    }

   运行以上代码即可获取mdb文件中所有管理的表。

三、动态获取字段名以及每个字段对应的属性值

   1、读取指定表信息

@TestpublicvoidreadTableData() throwsException {
StringmdbPath="F:/vector_data/other/gdal_demo_data/mdb-data/2015phone/20150210mobile.mdb";
StringmdbSql="SELECT * FROM mobileinfo";
List<Map<String, Object>>list=TestJdbcReadMdbCase.resolverMdb(mdbPath, mdbSql);
System.out.println(list.size());
    }

2、动态获取字段及属性值

/**** @param mdbPath mdb文件路径* @param mdbSql mdb执行sql* @param mdbColumnList mdb查询字段* @return* @throws Exception*/privatestaticList<Map<String, Object>>resolverMdb(StringmdbPath, StringmdbSql) throwsException {
if (mdbPath.isEmpty() ||mdbSql.isEmpty()) {
thrownewException("mdb文件路径不能为空或者SQL语句不能为空或者返回字段列表不能为空");
       }
List<Map<String, Object>>mdbEntityList=newArrayList<>();
Propertiesprop=newProperties();
//设置编码prop.put("charSet", "UTF-8");
//数据地址StringdbUrl="jdbc:ucanaccess://"+mdbPath;
//引入驱动Class.forName("net.ucanaccess.jdbc.UcanaccessDriver").newInstance();
try {
//连接数据库资源Connectionconn=DriverManager.getConnection(dbUrl, prop);
//建立查询事务Statementstatement=conn.createStatement();
//执行查询ResultSetresult=statement.executeQuery(mdbSql);
ResultSetMetaDatametaData=result.getMetaData();
intcount=metaData.getColumnCount();
List<String>mdbColumnList=newArrayList<String>(count);
//动态解析字段名for (inti=1; i<=count; i++) {
mdbColumnList.add(metaData.getColumnName(i));
           }
//解析执行结果Map<String, Object>mdbMapList=newHashMap<>(16);
while (result.next()) {
StringBuffersb=newStringBuffer();
for (Stringcol : mdbColumnList) {
//System.out.println(result.getObject(col));sb.append(col+"=="+result.getObject(col)).append("\t");
mdbMapList.put(col, result.getObject(col));
                }
System.out.println(sb.toString());
mdbEntityList.add(mdbMapList);
            }
       } catch (Exceptione) {
e.printStackTrace();
       }
//返回数据returnmdbEntityList;
   }

   上述代码跟普通的jdbc是一样的,都是加载驱动,获取结果集,从结果集中获取相应数据。程序输出如下图所示:

image.png

总结

   本文讲解了在java中使用jdbc的方式来解析非空间mdb数据,并给出了具体的关键代码,包括动态获取mdb的表名,通过表名获取字段名和属性值。希望对你有帮助。

目录
相关文章
|
12天前
|
前端开发 JavaScript Java
java常用数据判空、比较和类型转换
本文介绍了Java开发中常见的数据处理技巧,包括数据判空、数据比较和类型转换。详细讲解了字符串、Integer、对象、List、Map、Set及数组的判空方法,推荐使用工具类如StringUtils、Objects等。同时,讨论了基本数据类型与引用数据类型的比较方法,以及自动类型转换和强制类型转换的规则。最后,提供了数值类型与字符串互相转换的具体示例。
|
22天前
|
存储 缓存 安全
Java内存模型深度解析:从理论到实践####
【10月更文挑战第21天】 本文深入探讨了Java内存模型(JMM)的核心概念与底层机制,通过剖析其设计原理、内存可见性问题及其解决方案,结合具体代码示例,帮助读者构建对JMM的全面理解。不同于传统的摘要概述,我们将直接以故事化手法引入,让读者在轻松的情境中领略JMM的精髓。 ####
32 6
|
24天前
|
监控 算法 Java
Java虚拟机(JVM)的垃圾回收机制深度解析####
本文深入探讨了Java虚拟机(JVM)的垃圾回收机制,旨在揭示其背后的工作原理与优化策略。我们将从垃圾回收的基本概念入手,逐步剖析标记-清除、复制算法、标记-整理等主流垃圾回收算法的原理与实现细节。通过对比不同算法的优缺点及适用场景,为开发者提供优化Java应用性能与内存管理的实践指南。 ####
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
68 2
|
18天前
|
Java 编译器
Java 泛型详细解析
本文将带你详细解析 Java 泛型,了解泛型的原理、常见的使用方法以及泛型的局限性,让你对泛型有更深入的了解。
30 2
Java 泛型详细解析
|
18天前
|
缓存 监控 Java
Java线程池提交任务流程底层源码与源码解析
【11月更文挑战第30天】嘿,各位技术爱好者们,今天咱们来聊聊Java线程池提交任务的底层源码与源码解析。作为一个资深的Java开发者,我相信你一定对线程池并不陌生。线程池作为并发编程中的一大利器,其重要性不言而喻。今天,我将以对话的方式,带你一步步深入线程池的奥秘,从概述到功能点,再到背景和业务点,最后到底层原理和示例,让你对线程池有一个全新的认识。
47 12
|
15天前
|
存储 算法 Java
Java内存管理深度解析####
本文深入探讨了Java虚拟机(JVM)中的内存分配与垃圾回收机制,揭示了其高效管理内存的奥秘。文章首先概述了JVM内存模型,随后详细阐述了堆、栈、方法区等关键区域的作用及管理策略。在垃圾回收部分,重点介绍了标记-清除、复制算法、标记-整理等多种回收算法的工作原理及其适用场景,并通过实际案例分析了不同GC策略对应用性能的影响。对于开发者而言,理解这些原理有助于编写出更加高效、稳定的Java应用程序。 ####
|
15天前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
17天前
|
Java 数据库连接 开发者
Java中的异常处理机制:深入解析与最佳实践####
本文旨在为Java开发者提供一份关于异常处理机制的全面指南,从基础概念到高级技巧,涵盖try-catch结构、自定义异常、异常链分析以及最佳实践策略。不同于传统的摘要概述,本文将以一个实际项目案例为线索,逐步揭示如何高效地管理运行时错误,提升代码的健壮性和可维护性。通过对比常见误区与优化方案,读者将获得编写更加健壮Java应用程序的实用知识。 --- ####
|
21天前
|
数据采集 存储 Web App开发
Java爬虫:深入解析商品详情的利器
在数字化时代,信息处理能力成为企业竞争的关键。本文探讨如何利用Java编写高效、准确的商品详情爬虫,涵盖爬虫技术概述、Java爬虫优势、开发步骤、法律法规遵守及数据处理分析等内容,助力电商领域市场趋势把握与决策支持。