我正在使用一个Java程序的MySql数据库,现在我想把程序交给其他人。

如何导出MySql数据库结构没有数据在它,只是结构?


当前回答

获取单个表的创建脚本: -选择所有表格(用shift键) -只需右键单击表名,然后单击复制到剪贴板>创建语句。

其他回答

添加——routines和——events选项,以包括存储的例程和事件定义

mysqldump -u <user> -p --no-data --routines --events test > dump-defs.sql

使用mysql-backup4j,只需几行代码就可以很容易地备份任何数据库。这将为数据库生成SQL转储,稍后可以轻松地使用该转储恢复数据库。

为此需要的Maven依赖项是:

 <dependency>
        <groupId>com.smattme</groupId>
        <artifactId>mysql-backup4j</artifactId>
        <version>1.0.1</version>
    </dependency>

下面是在java中实现的..你可以使用很酷的参数集

/**
 * Creator : Tanvir Chowdhury
 * Date    : 2021-11-15
 */
public class BackupDatabase {
    public static void main(String[] args) throws Exception {

        Properties properties = new Properties();
        properties.setProperty(MysqlExportService.DB_NAME, "hcs_test_db");
        properties.setProperty(MysqlExportService.DB_USERNAME, "root");
        properties.setProperty(MysqlExportService.DB_PASSWORD, "root");
        properties.setProperty(MysqlExportService.DELETE_EXISTING_DATA, "true");
        properties.setProperty(MysqlExportService.DROP_TABLES, "true");
        properties.setProperty(MysqlExportService.ADD_IF_NOT_EXISTS, "true");
        properties.setProperty(MysqlExportService.JDBC_DRIVER_NAME, "com.mysql.cj.jdbc.Driver");
        properties.setProperty(MysqlExportService.JDBC_CONNECTION_STRING, "jdbc:mysql://localhost:3306/hcs_test_db");

        properties.setProperty(MysqlExportService.TEMP_DIR, new File("/Users/tanvir/Desktop/backups/backup.sql").toString());
        properties.setProperty(MysqlExportService.PRESERVE_GENERATED_ZIP, "true");

        MysqlExportService mysqlExportService = new MysqlExportService(properties);
        mysqlExportService.export();

    }
}

如果需要,您还可以使用邮件发送选项,很容易将备份文件发送到任何电子邮件地址。

或者你可以在mysqldump命令中使用——no-data选项。如果你想在java中执行此操作,那么将此命令作为参数传递给runtime exec()方法。

mysqldump -u root -h localhost --no-data -proot hcs_db_one?useSSL=false > db_one_dump.sql

如果您正在使用IntelliJ,您可以启用数据库视图(视图->工具窗口->数据库)

在该视图中连接到数据库。然后您可以右键单击数据库并选择“复制DDL”。其他ide可能提供类似的功能。

您还可以使用——no-data选项提取单个表

mysqldump -u user -h localhost --no-data -p database tablename > table.sql

MYSQL管理员工具是免费的 http://dev.mysql.com/downloads/gui-tools/5.0.html

你会发现许多选项导出你的MYSQL数据库