我正在尝试使用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”表。
有人能告诉我正确的方法吗?
答案 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);