gpt4 book ai didi

java - 如何在 Java 中将特定于平台的路径插入到数据库中

转载 作者:行者123 更新时间:2023-12-04 05:53:06 26 4
gpt4 key购买 nike

我正在开发一个应用程序,该应用程序处理放置在目录中的大量文件。我想将我的应用程序处理的每个文件的完全限定路径插入到数据库中。如果一个已经被应用程序处理过的文件重新提交给用户重新处理,那么我想通过指定文件的完全限定路径,从数据库中删除为该文件处理的所有数据,然后继续文件就好像它是一个新文件一样。

我面临的问题是,当我通过eclipse运行应用程序时,插入到数据库中的路径名如下:-

   D:\Trunk\App\Source

之后我将文件名与其路径(pathString + File.seperator + fileNameString)连接,即插入数据库的完全限定路径如下
   D:\Trunk\App\Source/file1.txt

但是,如果我为我的应用程序创建一个 jar 并通过双击该 jar 来运行该 jar,则插入到数据库中的路径名如下:-
   D:/Trunk/App/Source

在我将文件名与其路径(pathString + File.seperator + fileNameString)连接后,即插入数据库的完全限定路径如下
  D:/Trunk/App/Source/file1.txt  

如果通过双击 jar 而不是从 eclipse 运行应用程序来运行应用程序,则应用程序无法删除重新提交以进行处理的文件的数据。无论是从 eclipse 运行应用程序还是双击 jar,用于删除的查询都是相同的
    delete from file_table where where file = 'D:\Trunk\App\Source/file1.txt'

最佳答案

将路径转换为 ​​URI 并存储在数据库中。然后从 URI 创建文件。 String uriName = new File(path).toURI().toString() String path = new File(new URI(uriName)).getAbsolutePath();

关于java - 如何在 Java 中将特定于平台的路径插入到数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9835308/

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