devmachine/mongoimport 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

devmachine/mongoimport

最新稳定版本:1.0.4

Composer 安装命令:

composer require devmachine/mongoimport

包简介

Import MongoDB export into Doctrine.

README 文档

README

Build Status Coverage Status

PHP implementation of mongoimport.

About

Why would you need a custom mongoimport instead of default utility supplied with mongo? In certain setup (read Docker) mongo client is not available. With mongo extension enabled in PHP, you can import JSON created by mongoexport with this tiny library.

Provides integration with Symfony (read below), therefore could be used as fixtures loader.

Installation

Add the following to your composer.json:

{
    "require": {
        "devmachine/mongoimport": "~1.0"
    }
}

Usage

Import movies.json into hollywood database. Collection name is figured out automatically by using file's basename without extension.

$ ./bin/mongoimport movies.json --db hollywood

By default utility connects to mongod running on localhost:27017. In docker environment default host is MONGO_PORT_27017_TCP_ADDR and default port is MONGO_PORT_27017_TCP_PORT.

Overwriting default host, port and collection name:

$ ./bin/mongoimport movies.json -c shows --db hollywood --host <host> -p <port>

To drop existing collection prior to import, use --drop flag.

More info:

$ ./bin/mongoimport -h

Symfony integration

Register bundle in the kernel:

<?php
// app/AppKernel.php

public function registerBundles()
{
    $bundles = array(
        // ...
        
        new Doctrine\Bundle\MongoDBBundle\DoctrineMongoDBBundle(),
        new Devmachine\MongoImport\Bundle\DevmachineMongoImportBundle(),
    );
}

When DoctrineMongoDBBundle is enabled it registers the importer in container for each ODM manager e.g.

  • devmachine_mongoimport.default (for default manager)
  • devmachine_mongoimport.secondary (for secondary manager)
  • devmachine_mongoimport alias for default importer.

Example:

// Import movies.json into "movies" collection in default database.
$total = $this
    ->get('devmachine_mongoimport')
    ->importCollection('movies.json')
;

// Drop existing collection prior to import.
$total = $this
    ->get('devmachine_mongoimport')
    ->import('movies.json', ['drop' => true])
;

// With specified collection name.
$total = $this
    ->get('devmachine_mongoimport')
    ->import('movies.json', 'films', ['drop' => true])
;

// With specified collection and db.
$total = $this
    ->get('devmachine_mongoimport')
    ->import('movies.json', 'films', 'hollywood', ['drop' => true])
;

Contributing

Find below various docker commands.

Init
$ docker-composer up -d # puts mongo container in bg
Load fixtures
$ docker-compose run --entrypoint php composer fixtures/load.php
Exporting data

From container:

$ mongoexport --db company --collection employees --jsonArray --pretty --out employees.json
$ mongoexport --db company --collection offices --jsonArray --pretty --out offices.json

From host:

$ docker cp mongoimport_mongo_1:/employees.json ./tests/fixtures/
$ docker cp mongoimport_mongo_1:/offices.json ./tests/fixtures/
Running tests
$ docker-compose run --entrypoint php composer bin/phpunit
Running utility
$ docker-compose run --entrypoint php composer bin/mongoimport -V

统计信息

  • 总下载量: 8.81k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 2
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-10-29