java mysql 导入sql文件

试了好多命令行操作,目前只有这一种好用,其他的好像都不太行,理论上是可以的,不知道问题出在哪里

 public static boolean importDatabase() {
//		File saveFile = new File(mysqlExportPath);
//		if (!saveFile.exists()) {// 如果目录不存在
//			saveFile.mkdirs();// 创建文件夹
//		}
//		if (!importFilePath.endsWith(File.separator)) {
//			importFilePath = importFilePath + File.separator;
//		}

//		StringBuilder stringBuilder=new StringBuilder();
//		stringBuilder.append("mysql").append(" -h").append(mysqlHost);
//		stringBuilder.append(" -u").append(mysqlUser).append(" -p").append(mysqlPassword);
//		stringBuilder.append(" ").append(mysqlExportDatabaseName);
//		stringBuilder.append(" <").append(mysqlExportPath);
//        String importStr = new String(
//                "cmd /c mysql -h " + mysqlHost + " " + "-P " + mysqlLxPort + " " + "-u " + mysqlUser + " " + "-p " + mysqlPassword + " "+ "-D " + mysqlExportDatabaseName + " "
//                        + "-t " + mysqlTable + " < " + mysqlExportPath
//        );
//      mysql -u用户名 -p密码 -D数据库<sql文件[全路径全名] 如mysql -uroot -proot -Dtest<D:\test\test.sql
        String importStr = new String(
                "cmd /c mysql -u" + mysqlUser + " " + "-p" + mysqlPassword + " "+ "-D" + mysqlExportDatabaseName
                        + "<" + mysqlExportPath
        );

        System.out.println(importStr);
        try {
            Process process = Runtime.getRuntime().exec(importStr);//必须要有“cmd /c ”
            if (process.waitFor() == 0) {// 0 表示线程正常终止。
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return false;
    }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值