2017 © Pedro Peláez
 

library import-query-generator

An efficient query generator for mass resource import, distinguishing between new records and records to update.

image

kfirba/import-query-generator

An efficient query generator for mass resource import, distinguishing between new records and records to update.

  • Friday, January 12, 2018
  • by kfirba
  • Repository
  • 1 Watchers
  • 6 Stars
  • 69 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 2 Versions
  • 103 % Grown

The README.md

Import Query Generator

An efficient query generator for mass resource import, distinguishing between new records and records to update. This library uses MySQL's ON DUPLICATE KEY UPDATE feature., (*1)

Preface

I highly recommend you at least skim through my blog about this library to get a better understanding of this library., (*2)

Installation

You can add this library as a local, per-project dependency to your project using Composer:, (*3)

composer require kfirba/import-query-generator

Usage

use Kfirba\QueryGenerator;

$table = 'users';
$data = [
    ['name' => 'John', 'email' => 'john@example.com', 'password' => 'hashed_password', 'created_at' => date('Y-m-d'), 'updated_at' => date('Y-m-d')],
    ['name' => 'Jane', 'email' => 'jane@example.com', 'password' => 'hashed_password', 'created_at' => date('Y-m-d'), 'updated_at' => date('Y-m-d')],
    ['name' => 'Susy', 'email' => 'susy@example.com', 'password' => 'hashed_password', 'created_at' => date('Y-m-d'), 'updated_at' => date('Y-m-d')],
];
$excludedColumnsFromUpdate = ['password', 'created_at'];

$queryObject = (new QueryGenerator)->generate($table, $data, $excludedColumnsFromUpdate);

$queryObject->getQuery();
// -> "insert into `users` (`name`,`email`,`password`,`created_at`,`updated_at`) values (?,?,?,?,?),(?,?,?,?,?),(?,?,?,?,?) on duplicate key update `name`=VALUES(`name`),`email`=VALUES(`email`),`updated_at`=VALUES(`updated_at`)"

$queryObject->getBindings();
// -> ['John', 'john@example.com', 'hashed_password', '2018-01-12', '2018-01-12', 'Jane', 'jane@example.com', 'hashed_password', '2018-01-12', '2018-01-12', 'Susy', 'Susy@example.com', 'hashed_password', '2018-01-12', '2018-01-12']

As you may have noticed, the generator defaults to column=VALUES(column) since this is usually what we use when we attempt to bulk import some data. Need another behavior? You can submit a PR or just open an issue and we can talk about it 🤓., (*4)

License

This package is open-sourced software licensed under the MIT license., (*5)

The Versions

12/01 2018

dev-master

9999999-dev

An efficient query generator for mass resource import, distinguishing between new records and records to update.

  Sources   Download

MIT

The Development Requires

by Kfir Bens-Ami

12/01 2018

v1.0

1.0.0.0

An efficient query generator for mass resource import, distinguishing between new records and records to update.

  Sources   Download

MIT

The Development Requires

by Kfir Bens-Ami