H2数据库脚本无法导入MySQL

时间:2012-03-07 15:55:56

标签: mysql phpmyadmin h2

我创建了一个本地H2数据库,我总是在MySQL模式下打开以插入数据。现在,我想用SCRIPT导出它,以便在远程服务器上的远程MySQL数据库上用phpMyAdmin导入它。我得到以下内容:

SET LOCK_MODE 3;
;             
CREATE USER IF NOT EXISTS SA SALT '...' HASH '...' ADMIN;           
CREATE CACHED TABLE PUBLIC.RAWVALUEITEM(
    LANGUAGE VARCHAR(2) NOT NULL SELECTIVITY 1,
    RAWVALUE VARCHAR(40) NOT NULL SELECTIVITY 99,
    STRIPPED VARCHAR(40) NOT NULL SELECTIVITY 96
);
...

不幸的是,phpMyAdmin导入不满意:

#1193 - Unknown system variable 'LOCK_MODE'

当我手动删除set指令时,我会收到更多错误:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IF NOT EXISTS SA SALT '...' HASH '...' at line 1

我用来将数据库导出为脚本的代码是:

public static final String DB_DIR_LOCATION = "E:/Temp/FWDB/";
public static final String H2_CONNECTION = "jdbc:h2:file:"
    + DB_DIR_LOCATION + "FWDB_PHP_TEST" + "Mode=MySQL;IFEXISTS=TRUE";

public static void main(String[] args) throws SQLException {

    Connection conn = DriverManager.
        getConnection(H2_CONNECTION, "sa", "");

    PreparedStatement ps;

    ps = conn.prepareStatement("SCRIPT TO 'E:/Temp/FWDB/FWDB_EXPORT.gz' " 
        + "COMPRESSION GZIP");
    ps.execute();

}

如何从我的数据库生成一个脚本,该脚本将由我的远程服务器上的phpMyAdmin成功导入?

1 个答案:

答案 0 :(得分:1)

SCRIPT TO command生成的SQL脚本不是跨平台的。更好的解决方案可能是使用数据库工具,例如SQuirreL DB Copy Plugin或其他database tool