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

标签 java jackcess

我正在使用下面的代码在内存中创建 mdb 文件的副本,但它在 DatabaseBuilder 构造函数上给出空指针异常,表明不存在文件,我想要的是创建此操作的副本并将副本返回到输出流。

File tmp = new File("test.mdb");

FileChannel channel = MemFileChannel.newChannel(tmp,DatabaseImpl.RW_CHANNEL_MODE);

FileUtils.copyFile(file , tmp);

Database db = new DatabaseBuilder(tmp).setChannel(channel).open();

最佳答案

因此,您有一个预制的 Access 数据库文件作为项目中的资源。您可以使用 Jackcess 打开该数据库的内存中副本,首先使用 Class#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从 channel 打开Database:

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

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

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

关于java - 在内存中创建 mdb 副本时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52118619/

相关文章:

java - 用户 session 困惑::Spring Security

java - Jersey SSE 客户端未接收到事件

java - 瑞典语中带月份的日期字符串

java - 如何查询给定号码的联系人内容提供者

java - 使用 rJava 从 R 中使用 Jackcess

character-encoding - 使用 iso-8859-1 在 Wildfly 中打开 ucanaccess/jackcess 数据库

java - Jackcess 列乱序?

java - 没有参数和默认构造函数混淆

java - UCanAccess 似乎无法使用 getBytes() 读取 OLE 对象列

java - Jackcess:MSAccess 数据库的字符集错误