Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/schumacherfm/magento2-data-migration

This script migrates your Magento1 database to Magento2
https://github.com/schumacherfm/magento2-data-migration

Last synced: 17 days ago
JSON representation

This script migrates your Magento1 database to Magento2

Awesome Lists containing this project

README

        

# Magento 2 DB Migration

Migrates database from Magento 1.8,1.9 to Magento 2 beta5.

This program comes with ABSOLUTELY NO WARRANTY.

For each new Magento2 release/pre-release this module must be adapted, mainly when there are new setup scripts.

Also Magento2 will change a lot of code so that more internal refactoring here will be necessary.

## Installation

Only via composer possible.

Add to your `required-dev` section in your `composer.json`:

```
"require-dev": {
...
"schumacherfm/mage1-to-mage2": "dev-master",
...
},

...

"repositories": [
...
{
"type": "vcs",
"url": "[email protected]:SchumacherFM/Magento2-Data-Migration.git"
},
...
```

Run the command to update your installation:

```
$ composer.phar update
```

## Usage

Jump to your Magento2 root directory and call the `migrator`:

```
$ vendor/bin/migrator
Magento2 Migrator version 0.0.1 by Cyrill Schumacher

You must read the help. Run: vendor/bin/migrator help migrate_xx

Usage:
[options] command [arguments]

Options:
--help (-h) Display this help message
--quiet (-q) Do not output any message
--verbose (-v|vv|vvv) Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
--version (-V) Display this application version
--ansi Force ANSI output
--no-ansi Disable ANSI output
--no-interaction (-n) Do not ask any interactive question

Available commands:
help Displays help for a command
list Lists commands
migrate_ce Database migration process for community edition
migrate_ee Database migration process for enterprise edition.
```

### Help for migrate_ce

```
$ vendor/bin/migrator help migrate_ce
Usage:
migrate_ce [--host[="..."]] [--username[="..."]] [--password[="..."]] [--dbname[="..."]] [--prefix[="..."]]

Options:
--host Database host_name:port (default: "localhost")
--username Database user name (default: "root")
--password Database password
--dbname Database name
--prefix Table name prefix (default: "")
--help (-h) Display this help message
--quiet (-q) Do not output any message
--verbose (-v|vv|vvv) Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
--version (-V) Display this application version
--ansi Force ANSI output
--no-ansi Disable ANSI output
--no-interaction (-n) Do not ask any interactive question

Help:
This program comes with ABSOLUTELY NO WARRANTY.

No tables will be dropped except catalog_category_flat* and catalog_product_flat_*.
Truncated table is core_resource.
Obsolete tables will have the prefix zz_ in their name.
Obsolete columns starts with z_.
All keys and indexes on all tables will be dropped and recreated with the original install scripts.
If you have custom foreign keys you must recreate them yourself afterwards.

Increase verbosity to see the SQL commands: -v or -vvv

How to start:

1. Create a new MySQL database
2. Copy all tables and data into the new database for magento2
3. Enter the new database access data either into app/config.php or
use the command line options here.
4. Run the migration tool and wait ...
5. Clear caches of Magento2
6a. Follow the steps in https://github.com/magento/magento2/issues/1000#issue-55454189
6b. Run: "$ php -f index.php update" in the root/setup directory
6c. Check EAV tables IF you have custom models they will have the prefix Magento and not
your namespace. @todo
7. Reindex everything on the CLI
8. Cross fingers & Load Magento2 backend or frontend

Expected errors:

1. Column "code" does not exist in table "widget". (because column name is already widget_code)
2. Column "type" does not exist in table "widget"
3. Maybe: some renaming error for googleoptimizer_code

Your work/review after the migration:
- Table cms_page: old column root_template new column page_layout => strings are written differently!
- Table widget_instance: Update the theme.
- Table core_layout_link
- Table zz_googleoptimizer_code compared to googleoptimizer_code
- Table zz_core_url_rewrite compared to url_rewrite. For SEO reasons you can try to rebuild existing URLs ...
- Check categories and remove Default ones.
```

### Help for migrate_ee

@todo Looking for help here or pay me.

## Missing Features aka Bugs

- Table Prefix has not been properly implemented. Too lazy ;-(
- There needs another CLI flag with which you can provide your Namespace_Module names for converting the model names
in all eav tables.
- Cannot login into backend (I even copied the tables from a clean Mage2 install but didn't work. Need to dig deeper.)

## Compatibility

- Magento >= 2
- php >= 5.4.11

## Support / Contribution

Report a bug using the issue tracker or send us a pull request.

Instead of forking I can add you as a Collaborator IF you really intend to develop on this module. Just ask :-)

We work with: [A successful Git branching model](http://nvie.com/posts/a-successful-git-branching-model/) and [Semantic Versioning 2.0.0](http://semver.org/)

Licence
-------
[OSL - Open Software Licence 3.0](http://opensource.org/licenses/osl-3.0.php)

Author
------

[Cyrill Schumacher](http://www.schumacher.fm)

[My pgp public key](http://www.schumacher.fm/cyrill.asc)