[英]Can I run a “source” command (SQL script) from a JDBC connection?
我正在编写一个具有数据访问层的应用程序,以抽象化到SQLITE3或MySQL数据库的基础连接。
昨天在这里有了一些帮助,向我展示了如何使用流程生成器来使用输出重定向将命令行导入到SQLITE3 DB中。
现在,我试图通过导入转储文件在MySQL中创建相同的数据库。 从命令行客户端加载工作正常。 我只是告诉它源文件,并且数据库创建成功。
但是,我试图在运行时通过代码来执行此操作,并且我执行SQL语句的方法无法执行源命令。
我怀疑这是因为“源”不是SQL,但是我不知道尝试使用其他什么来运行它。
我的错误消息是:
java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'source /tmp/ISMCoreActionPack_mysql.sql' at line 1
失败的命令字符串:
source /tmp/ISMCoreActionPack_mysql.sql;
我的方法是:
public Boolean executeSqlStatement(String sql) {
Boolean rc = false;
try {
Connection connection = getConnection();
Statement statement = connection.createStatement();
rc = statement.execute(sql);
connection.close();
} catch (SQLException e) {
e.printStackTrace();
System.err.println(e.getClass().getName() + ": " + e.getMessage());
System.exit(1);
}
return rc;
}
谁能建议该怎么做?
您不能运行'source'命令,因为JDBC驱动程序不支持它,只有MySQL不支持。
我对您的建议如下。 编写一些解析器,该解析器从文件读取查询,并使用JDBC语句执行查询。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.