-1

嘿伙计们,我已经搜索了许多其他答案,但仍然无法弄清楚这个问题。

statement.executeUpdate("CREATE TABLE IF NOT EXISTS recentlyWatched (fileName STRING NOT NULL, fileLocation STRING, viewCount INTEGER, PRIMARY KEY (fileName))");

Class.forName("org.sqlite.JDBC");
        connection = DriverManager.getConnection("jdbc:sqlite:media.db");
        statement = connection.createStatement();
        statement.executeUpdate("INSERT INTO recentlyWatched (fileName, fileLocation, viewCount) VALUES ('"
                + fileName + "', '"
                + fileLocation + "', 0) ON DUPLICATE KEY UPDATE viewCount = '1'");

我尝试了多种方法来解决此问题,并且每当我尝试插入记录时都会感到茫然,我得到“java.sql.SQLException:接近“ON”:语法错误”。

更新

最终代码看起来像这样

statement.executeUpdate("INSERT OR IGNORE INTO recentlyWatched (fileName, fileLocation, viewCount) VALUES ('"
                + fileName + "', '"
                + fileLocation + "', 0)");
        statement.executeUpdate("UPDATE recentlyWatched SET viewCount = viewCount + 1 WHERE '" + fileName + "' LIKE fileName;");
4

2 回答 2

5

Class.forName("org.sqlite.JDBC")您可以看出,您使用的是不支持该ON DUPLICATE子句的 SQLite 数据库。这就是您收到此错误的原因。

检查问题以获取解决方法。

于 2013-08-24T08:09:20.220 回答
1

作为替代方案,我建议像这样使用它

("REPLACE INTO recentlyWatched (fileName, fileLocation, viewCount) VALUES ('"
                + fileName + "', '"
                + fileLocation + "', 0)

不同之处在于是先做一个DELETE然后再做一个INSERT

于 2013-08-24T08:15:41.930 回答