【问题标题】:Can I export a Sqlite db using RedBean PHP ORM and Import to MySQL?我可以使用 RedBean PHP ORM 导出 Sqlite 数据库并导入到 MySQL 吗?
【发布时间】:2016-04-10 00:14:01
【问题描述】:

我有一个简单的网络应用程序,我一直在使用redbean PHP 构建它,它的结构非常简单,包含三种 bean 类型:

区域 建筑物 人

所有关系都是排他的 1:Many。所以,Person 只属于 1 个Building,而Building 属于 1 个Area

Area
  BuildingList
    PersonList

目前,为了便于开发,我一直在使用Sqlite3 进行开发,但我想将数据移动到mySQL。我已经添加了很多数据。

有没有一种简单的方法可以使用 RedBean 将所有 bean 导出到新的 MySql 数据库?

我知道我可以搜索 sqlite -> MySQL/MariaDB 转换器,但我也可能希望能够反向使用它来使迁移站点超级容易移动/备份/更改数据库。

我在下面尝试了什么:

R::setup('sqlite:/' . __DIR__ . '/data/database.db'); 
R::addDatabase('mysql', $MySqlConn );

$old_datas = R::findAll( 'area' );
R::selectDatabase( 'mysql' );

foreach ($old_datas as $bean) {
    $new_area = R::dispense('area');
    $new_area->importFrom( $bean );
    $id = R::store( $new_area );
    var_dump( $new_area ); // shows new data
}

var_dump( R::findAll( 'area' ) ); // returns empty array

【问题讨论】:

  • 你试过exportAll()中提到的redbean docs吗?
  • exportAll() 很棒,并且可以使用递归添加到 MySQL 数据库。我并没有在这条路上走得太远,但看起来我越来越有可能不得不像这样手动编写函数来完成它。
  • 我可以推荐Fregata(免责声明:我是作者)吗?如果您愿意,可以使用 demo projectMySQLPostgreSQL 示例迁移。它与 ORM/数据库无关,虽然有一个集成的 Doctrine DBAL 外键迁移系统,但您可以忽略它。我从未与 RedBean 合作过,但如果您有具体要求,我很乐意写详细的答案。

标签: php mysql sqlite redbean


【解决方案1】:

我会先说我个人没有尝试这样做,但是由于您可以通过 sqlite3 控制台转储整个数据库,所以我的第一种方法是这样做,然后尝试导入该文件进入 MySQL。

从 sqlite 控制台转储一个 sqlite3 数据库:

sqlite> output database_dump.sql sqlite> .dump sqlite> .quit

将 .sql 文件导入 MySQL(如 here 所述):

mysql> use DATABASE_NAME mysql> source path/to/file.sql

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-05-08
    • 2014-05-05
    • 1970-01-01
    • 1970-01-01
    • 2014-12-09
    • 2019-11-12
    • 2021-05-26
    • 2016-08-27
    相关资源
    最近更新 更多