我有一个 cvs 文件,其架构是,每个字段都用 " 包围,并用 分隔,每个元组都是带有 \n 的换行符
所以在我的Java文件中,我写了
String path = "o.csv";
String esquel = " LOAD DATA LOCAL INFILE " + path +
" INTO TABLE recommendations " +
" FIELDS TERMINATED BY \',\' ENCLOSED BY \'\"'" +
" LINES TERMINATED BY \'\\n\'";
Run Code Online (Sandbox Code Playgroud)
我用以下语句执行该语句
statement.executeUpdate(esquel);
Run Code Online (Sandbox Code Playgroud)
但它会抛出一个 SQLException,其中显示:
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,了解在第 1 行的 'o.csv INTO TABLE 建议字段 TERMINATED BY ',' ENCLOSED BY '"' LINES' 附近使用的正确语法
我的错误是什么?
如果您能帮助我,我将不胜感激。
谢谢
小智 5
这是我测试过的工作代码:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class LoadTRPLog2MySql {
public static void main(String[] args) {
Class driver_class = null;
try {
driver_class = Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
return;
}
System.out.println("found driver" + driver_class);
Connection connection = null;
try {
connection = DriverManager.getConnection("jdbc:mysql://mysqlserver.com:3306/dbname", "myid","pwd");
} catch (SQLException e) {
e.printStackTrace();
}
try {
System.out.println("Established connection to " + connection.getMetaData().getURL());
} catch (SQLException e1) {
e1.printStackTrace();
}
Statement statement = null;
try {
statement = connection.createStatement();
Statement statement1 = connection.createStatement();
//windows
//statement1.executeUpdate( "LOAD DATA LOCAL INFILE 'C:\\Users\\senthil_sivasamy\\Documents\\Projects\\messageprocessing\\log.txt' INTO TABLE trpwatchlog_tb FIELDS TERMINATED BY ' ' LINES TERMINATED BY '\\n'");
//linux ( " LOAD DATA LOCAL INFILE '/home/username/logname.log' INTO TABLE logname.log FIELDS TERMINATED BY ' ' LINES TERMINATED BY '\\n'");
statement.executeUpdate( "LOAD DATA LOCAL INFILE '/home/username/avail30trplog' INTO TABLE logname.log FIELDS TERMINATED BY ' ' LINES TERMINATED BY '\\n'");
statement1.execute("select * from dbname.tablelog_tb");
ResultSet rs = statement1.getResultSet();
System.out.println("Row hostname and timestamp");
while(rs.next()) {
System.out.println("Row hostname and timestamp");
System.out.println(rs.getRow());
System.out.println(""+rs.getString("hostname"));
System.out.println(""+rs.getString("timestamp"));
}
rs.close();
} catch(SQLException e) {
} finally {
if (statement != null) {
try {
statement.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
if (connection != null) {
try {
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
Run Code Online (Sandbox Code Playgroud)