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

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 本文讲解了在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的表名,通过表名获取字段名和属性值。希望对你有帮助。

目录
相关文章
|
10天前
数据解析之xpath 太6了
数据解析之xpath 太6了
|
6天前
|
消息中间件 canal 关系型数据库
Maxwell:binlog 解析器,轻松同步 MySQL 数据
Maxwell:binlog 解析器,轻松同步 MySQL 数据
41 11
|
11天前
|
数据采集 存储 JavaScript
构建您的第一个Python网络爬虫:抓取、解析与存储数据
【9月更文挑战第24天】在数字时代,数据是新的金矿。本文将引导您使用Python编写一个简单的网络爬虫,从互联网上自动抓取信息。我们将介绍如何使用requests库获取网页内容,BeautifulSoup进行HTML解析,以及如何将数据存储到文件或数据库中。无论您是数据分析师、研究人员还是对编程感兴趣的新手,这篇文章都将为您提供一个实用的入门指南。拿起键盘,让我们开始挖掘互联网的宝藏吧!
|
7天前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
20 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
8天前
|
安全 Java 开发者
Java修饰符与封装:理解访问权限、行为控制与数据隐藏的重要性
Java中的修饰符和封装概念是构建健壯、易维护和扩展的Java应用程序的基石。通过合理利用访问权限修饰符和非访问修饰符,开发者能够设计出更加安全、灵活且高效的代码结构。封装不仅是面向对象编程的核心原则之一,也是提高软件项目质量和可维护性的关键策略。
12 1
|
13天前
|
缓存 负载均衡 Dubbo
Dubbo技术深度解析及其在Java中的实战应用
Dubbo是一款由阿里巴巴开源的高性能、轻量级的Java分布式服务框架,它致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
39 6
|
10天前
|
监控 算法 Java
深入解析Java中的垃圾回收机制
本文旨在全面解析Java的垃圾回收机制,探讨其工作原理、常见算法以及在实际开发中的应用。通过对这一重要主题的深入分析,希望帮助读者更好地理解Java虚拟机(JVM)如何管理内存,从而编写出更高效、稳定的Java应用程序。
|
10天前
|
Java 开发者
Java中的异常处理机制深度解析
在Java编程中,异常处理是保证程序稳定性和健壮性的重要手段。本文将深入探讨Java的异常处理机制,包括异常的分类、捕获与处理、自定义异常以及一些最佳实践。通过详细讲解和代码示例,帮助读者更好地理解和应用这一机制,提升代码质量。
12 1
|
11天前
|
分布式计算 Java API
深入解析Java中的Lambda表达式及其应用
本文将深入探讨Java中Lambda表达式的定义、优势及其在实际编程中的应用。通过具体示例,帮助读者更好地理解和使用这一强大的编程工具。
|
7天前
|
安全 Java 调度
Java编程时多线程操作单核服务器可以不加锁吗?
Java编程时多线程操作单核服务器可以不加锁吗?
21 2

热门文章

最新文章

推荐镜像

更多
下一篇
无影云桌面