gpt4 book ai didi

java - 使用 HSQLDB JDBC 驱动程序的 CSV 上的 SQL

转载 作者:行者123 更新时间:2023-12-04 06:13:45 25 4
gpt4 key购买 nike

我有一个预生成的 CSV 文件,我需要在该文件上运行 SQL 查询。我一直在寻找不同的开源解决方案(例如 CsvJdbc、xlSQL 等),但还没有真正找到任何令人满意的东西。

CsvJdbc 无法识别 ORDER BY、GROUP BY 等
xlSQL 只能在 XLS 文件上运行,而不是 CSV(或者我无法让它与 CSV 一起运行。有人知道如何吗?)。此外,它不再处于开发或支持状态。

我在某处读到 HSQLDB 支持对 CSV 文件进行查询,但我无法正常工作。这是我到目前为止所做的:

如果我使用 HSQLDB 创建一个 CSV 文件,那么它就能够成功执行查询。这是代码:

String driver = "org.hsqldb.jdbcDriver";
Driver d = (Driver) Class.forName(driver).newInstance();
String protocol = "jdbc:hsqldb:file";
final String url = "jdbc:hsqldb:file:/C:/Users/varun.achar/Documents";

final StringBuilder createTable = new StringBuilder();
createTable.append("CREATE TEXT TABLE currency (");
createTable.append("id INT PRIMARY KEY, name VARCHAR)");
final StringBuilder linkTable = new StringBuilder();
linkTable.append("SET TABLE currency SOURCE ");
linkTable.append("\"/currencies.csv");
linkTable.append(";ignore_first=true;all_quoted=true\"");
Connection conn = DriverManager.getConnection(url, "sa", "");
Statement stm = conn.createStatement();
stm.execute(createTable.toString());
stm.execute(linkTable.toString());
ResultSet resultSet = stm.executeQuery("SELECT * FROM CURRENCY");
if (resultSet != null) {
while (resultSet.next()) {
System.out.println("CURRENCY = " + resultSet.getString(2));
}
}
conn.close();

但是当我删除文件并再次运行它时,同样的事情不起作用!我收到错误

Table already exists: CURRENCY in statement [CREATE TEXT TABLE currency]



另外,如果我有一个预先存在的 csv 文件(格式是正确的,因为我能够使用 CsvJDBC 运行一个简单的选择语句)然后我得到错误

Table not found: RMS in statement [SET TABLE rms]



代码
final StringBuilder linkTable = new StringBuilder();
linkTable.append("SET TABLE rms SOURCE ");
linkTable.append("\"C:/myreports/temp/user/1316083232009/rms.csv");
linkTable.append(";ignore_first=true;all_quoted=true\"");
Driver d = (Driver) Class.forName(driver).newInstance();
System.out.println("Driver was successfully loaded.");
String protocol = "jdbc:hsqldb:file";
String database = "C:\\myreports\\temp\\user\\1316083232009\\rms.csv";
String url = protocol + ":" + database;
con = DriverManager.getConnection(url);
stm = con.createStatement();
stm.execute(linkTable.toString());
resultSet = stm.executeQuery(testSQLStatement());
if (resultSet != null) {
while (resultSet.next()) {
System.out.println("FULL NAME = "+ resultSet.getString("usr_FULL_NAME"));
}
}

有人可以对此有所了解吗?

谢谢

最佳答案

单个 HSQLDB 数据库可以有多个表,包括多个 TEXT 表。您似乎认为每个文本表必须有一个数据库,但事实并非如此。

数据库路径不是目录。它也不是 CSV 文件。在您的第一个示例中,您应该指定一个数据库名称,如下所示:

final String url = "jdbc:hsqldb:file:/C:/Users/varun.achar/Documents/mydb";

在你的第二个例子中也是如此。

该数据库由几个以您指定的名称开头的文件组成。在本例中,您将拥有 mydb.properties , mydb.script , 等等。
CREATE TEXT TABLE ...语句为表创建元数据。此表元数据保留在数据库中。

然后第一个示例将起作用。如果您删除 CSV 文件,然后打开数据库,“CREATE TEXT TABLE”语句仍存储在数据库中,因此当您再次尝试创建同一个表时,它会报错。

如果你有一个预先存在的 CVS 文件,你仍然需要从 CREATE TEXT TABLE ... 开始,然后使用 SET TABLE 语句将其与 CVS 链接,方法与第一个示例相同。

关于java - 使用 HSQLDB JDBC 驱动程序的 CSV 上的 SQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7512119/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com