如何使用Jackcess在Access .mdb中创建ODBC链接表?

时间:2012-10-09 11:54:55

标签: java ms-access odbc jackcess

我正在尝试使用Jackcess在Access .mdb中创建ODBC链接表。

Final String connStr = "ODBC;DRIVER={Sybase ASE ODBC Driver};NA=dbhostname,port;DB=myDbName;UID=myID;PWD=myPass;FILEDSN=path//myDSN.dsn";

Database mdb =Database.create(new File("./test.mdb");
mdb.createLinkedTable("testLinkTable",connStr, "targetTableName");

当我打开test.mdb时,我可以看到“testLinkTable”,但链接类型是“Access Link”。 我期望在test.mdb中创建“ODBC Link”表。

有人能告诉我正确的方法吗?

1 个答案:

答案 0 :(得分:0)

看来Jackcess中的.createLinkedTable()方法目前只能创建到另一个Access数据库中的表的链接。我刚刚使用Jackcess 2.0.1对此进行了测试,并且以下代码成功创建了一个名为[Clients]的Access链接表,该表指向另一个Access数据库:

Database database = DatabaseBuilder.open(new File("C:\\__tmp\\jTest\\linkTest.accdb"));
String linkedTableLocalName = "Clients";
String linkedTableSource = "C:\\Users\\Public\\Database1.accdb";
String linkedTableRemoteName = "Clients";
database.createLinkedTable(linkedTableLocalName, linkedTableSource, linkedTableRemoteName);

但是,此代码创建了一个名为[dbo_Addresses]的链接表,看起来像,就像指向另一个Access数据库的链接(不是预期的ODBC链接表),并且不起作用:

Database database = DatabaseBuilder.open(new File("C:\\__tmp\\jTest\\linkTest.accdb"));
String linkedTableLocalName = "dbo_Addresses"; 
String linkedTableSource = "ODBC;DSN=myDb;Trusted_Connection=Yes;APP=Microsoft Office 2010;DATABASE=myDb;";  
String linkedTableRemoteName = "dbo.Addresses";
database.createLinkedTable(linkedTableLocalName, linkedTableSource, linkedTableRemoteName);