首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >导入数据时,在哪里存储文本文件?

导入数据时,在哪里存储文本文件?
EN

Stack Overflow用户
提问于 2015-11-24 20:58:49
回答 3查看 204关注 0票数 0

我在Netbeans中创建了一个JDBC,它将数据从文本文件加载到表中。当我在另一台计算机上运行程序时,文件路径(我认为这就是它的名称)将是不同的。

文本文件在我的桌面上。这意味着,如果我必须从另一台计算机上运行程序,我将得到一个错误,因为文件显然不是在原始计算机上的同一位置找到的。

我创建了一个字符串来将数据加载到数据库中,如下所示:

代码语言:javascript
运行
复制
String loadData = "load data local infile '/Users/Ricky/Desktop/table_data.txt'" +
                      "into table T1;";   

我可以在netbeans项目中创建一个文件夹来存储文本文件吗?所以它可以从任何有相同路径的计算机上访问?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-11-24 21:03:51

一个解决方案是使用相对路径,正如这里所解释的那样

您必须做的是不使用绝对位置(即“C:\FolderName\filename.txt”),使用相对位置(即“table_data.txt”)。

在您的例子中,这转化为使用

代码语言:javascript
运行
复制
String loadData = "load data local infile 'table_data.txt'" +
                      "into table T1;";  

这样做是从加载文件,与从运行应用程序的文件夹相同。

另一种解决方案是使用JFileChooser,它允许用户从它保存的任何目录中查找文件。

票数 2
EN

Stack Overflow用户

发布于 2015-11-24 21:03:01

如果从与数据文件相同的目录运行程序,则可以使用:

代码语言:javascript
运行
复制
String loadData = "load data local infile 'table_data.txt'" +
                  "into table T1;";

通过指定任何路径,程序将在当前工作目录(启动程序的目录)中查找。

票数 1
EN

Stack Overflow用户

发布于 2015-11-24 21:12:59

您可以有一个可选的命令行参数:

代码语言:javascript
运行
复制
public class Main {

    private static final String LOAD_COMMAND = "load data local infile '%s' into table T1;";
    private static final String DEFAULT_FILE = System.getProperty("user.home") + "/table_data.txt";

    public static void main(String[] args) {
        String file = (args.length > 0) ? args[0] : DEFAULT_FILE;
        String command = String.format(LOAD_COMMAND, file);
        System.out.println(command);
    }
}

如果您在Main.java中保存了上述内容,您可以很容易地对其进行测试。

代码语言:javascript
运行
复制
javac Main.java && java -cp . Main

将印刷:

代码语言:javascript
运行
复制
load data local infile '/Users/<your-username>/table_data.txt' into table T1;

代码语言:javascript
运行
复制
javac Main.java && java -cp . Main /my/file

将印刷:

代码语言:javascript
运行
复制
# load data local infile '/my/file' into table T1;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33903677

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档