0

我有一个 .mwb 数据库,但我需要在我的 phpmyadmin 中加载它(我已经安装了 Wamp)。我试图安装 mysql 工作台,但它检测到另一个 mysql,我取消了安装。

如何将其转换为获取此 .mwb 的 .sql 文件?

谢谢!

4

1 回答 1

1

Workbench 模型是一个压缩文件(换句话说,一个重命名的 ZIP 文件)。您应该可以使用任何体面的存档器打开它。在里面,有一个 XML 文件。我不知道格式是否记录在案,但看起来很简单:

<value type="object" struct-name="db.mysql.Table" id="{DF899AC1-6CAA-42A8-A584-A663E17596E9}" struct-checksum="0x1a403946">
  <value type="string" key="avgRowLength"></value>
  <value type="int" key="checksum">0</value>
  <value _ptr_="0971BA88" type="list" content-type="object" content-struct-name="db.mysql.Column" key="columns">
    <value type="object" struct-name="db.mysql.Column" id="{A742D230-C0CE-48C7-88E0-B5DB74409FE4}" struct-checksum="0x783b5183">
      <value type="int" key="autoIncrement">1</value>
      <value type="string" key="characterSetName"></value>
      <value _ptr_="0971BF08" type="list" content-type="object" content-struct-name="db.CheckConstraint" key="checks"/>
      <value type="string" key="collationName"></value>
      <value type="string" key="datatypeExplicitParams"></value>
      <value type="string" key="defaultValue"></value>
      <value type="int" key="defaultValueIsNull">0</value>
      <value _ptr_="0971BF98" type="list" content-type="string" key="flags">
        <value type="string">UNSIGNED</value>
      </value>
      <value type="int" key="isNotNull">1</value>
      <value type="int" key="length">-1</value>
      <value type="string" key="name">invoice_id</value>
      <value type="int" key="precision">10</value>
      <value type="int" key="scale">-1</value>
      <link type="object" struct-name="db.SimpleDatatype" key="simpleType">com.mysql.rdbms.mysql.datatype.int</link>
      <value type="string" key="comment"></value>
      <value type="string" key="oldName">invoice_id</value>
      <link type="object" struct-name="GrtObject" key="owner">{DF899AC1-6CAA-42A8-A584-A663E17596E9}</link>

所以你基本上需要花几天时间编写一个解析 XML 并编写 SQL 代码的脚本。

(老实说,考虑到最初的 Workbench 是免费且跨平台的,我认为这会浪费时间。)

于 2013-11-13T15:47:33.860 回答