java - 从 java swing 导出和导入数据库 mysql

标签 java mysql jdbc export

我想从我的 swing 应用程序导出数据库 tp 做一个备份 我在谷歌上搜索了一下,唯一能与我合作的方法是这样的:

FileWriter fw = null;                   

String path="C:/Users/mypc/Desktop/tesst/back.sql";
String dumpCommand ="mysqldump -u root --password= gestiondestock > "+path;
// Runtime.getRuntime().exec("mysqldump -u root --password= gestiondestock > "+path);
File data = new File(path);

try{
    fw = new FileWriter(data);
    fw.close();
}catch(IOException ex){
    ex.printStackTrace();
}

Runtime rt = Runtime.getRuntime();

try {
    Process proc = rt.exec(dumpCommand);
    InputStream in = proc.getInputStream();
    InputStreamReader read = new InputStreamReader(in,"latin1");
    BufferedReader br = new BufferedReader(read);
    BufferedWriter bw = new BufferedWriter(new FileWriter(data,true));
    String line=null;
    StringBuffer buffer = new StringBuffer();
    
    while ((line=br.readLine())!=null){
        buffer.append(line+"\n");
    }
    String toWrite = buffer.toString();
    bw.write(toWrite);
    bw.close();
    br.close();
} catch (IOException e) {
    e.printStackTrace();
}

但我只得到日期基础信息而不是创建表并插入到....

我只得到这些信息:

-- MySQL 转储 10.10

-- 主机:localhost 数据库:gestiondestock


-- 服务器版本 5.1.36-community-log

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS,    FOREIGN_KEY_CHECKS=0 */;
  /*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
   /*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

如何解决这个问题并获取有关 sql 文件的所有信息??,当我尝试在 phpmyadmin 上导出时,我获取了所有信息

dumpCommand 在 cmd 框中手动工作正常

以及导入它的最佳方式!!


解决方案

我不能在不运行 shell 的情况下进行重定向,而我在上面没有这样做。 所以我必须这样做:

 String path="C:/Users/mypc/Desktop/tesst/back.sql";
 String dumpCommand = "mysqldump -u root gestiondestock --result-file="+path;

--结果文件="+路径

最佳答案

这似乎是 mysqldump 命令的问题。而不是这个

mysqldump -u root --password= gestiondestock > path

试试这个,

mysqldump -u root -p[root_password] [database_name] > dumpfilename.sql

另请参阅此链接,

http://www.thegeekstuff.com/2008/09/backup-and-restore-mysql-database-using-mysqldump/

关于java - 从 java swing 导出和导入数据库 mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12140267/

相关文章:

php - 如何从插入数据pdo mysql中获取数据

postgresql - 从 Dataframe 到 DB 的批量插入忽略 Pyspark 中的失败行

java - Spring 启动: Cannot access REST Controller on localhost (404)

java - Maven/Hibernate——为什么在 ConstraintViolationException 上出现 NoClassDefFoundError?

java - 如何尽可能快地插入数据库(多线程程序)?

MySQL - 选择具有指定 ID 或 null 的结果

jdbc - UTF8mb4 unicode 破坏 MariaDB JDBC 驱动程序

java - 无法从 Web 应用程序通过 JDBC 连接到 HIVE

java - 删除/释放 Java 中的链表节点。请提出建议

java - 尝试从 Oracle 数据库读取 XML 以创建 MD5 哈希值