为了账号安全,请及时绑定邮箱和手机立即绑定

在内存中创建 mdb 副本时出错

在内存中创建 mdb 副本时出错

HUH函数 2021-08-25 09:44:43
我正在使用下面的代码在内存中创建 mdb 文件的副本,但它在 DatabaseBuilder 构造函数上给出了空指针异常,即不存在文件,我想要的是创建此操作的副本并将副本返回到输出流。File tmp = new File("test.mdb");FileChannel channel = MemFileChannel.newChannel(tmp,DatabaseImpl.RW_CHANNEL_MODE);FileUtils.copyFile(file , tmp);数据库 db = new DatabaseBuilder(tmp).setChannel(channel).open();
查看完整描述

1 回答

?
暮色呼如

TA贡献1853条经验 获得超9个赞

因此,您有一个预制的 Access 数据库文件作为项目中的资源。您可以使用 JackcessClass#getResourceAsStream打开该数据库的内存副本,方法是首先使用打开资源...


final String dbResourcePath = "/embedded.accdb";

@SuppressWarnings("rawtypes")

Class thisClass = JackcessTestMain.class;  // my "main" class

InputStream dbResourceStream = null;

// for running from executable jar 

dbResourceStream = thisClass.getResourceAsStream("/resources" + dbResourcePath);

if (dbResourceStream == null) {

    // for running inside the Eclipse IDE

    dbResourceStream = thisClass.getResourceAsStream(dbResourcePath);

}

...将其传递InputStream给 Jackcess MemFileChannel...


MemFileChannel mfc = MemFileChannel.newChannel(dbResourceStream);

...然后使用从频道DatabaseBuilder打开Database:


Database db = new DatabaseBuilder().setChannel(mfc).open()

完成对数据库内存副本的更改后,您可以将通道的内容发送到 OutputStream。例如,


db.close();

FileOutputStream fos = new FileOutputStream("C:/Users/Public/zzz.accdb");

mfc.transferTo(fos);

fos.close();


查看完整回答
反对 回复 2021-08-25
  • 1 回答
  • 0 关注
  • 172 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信