【发布时间】: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 project 和 MySQL 到 PostgreSQL 示例迁移。它与 ORM/数据库无关,虽然有一个集成的 Doctrine DBAL 外键迁移系统,但您可以忽略它。我从未与 RedBean 合作过,但如果您有具体要求,我很乐意写详细的答案。