项目作者: mgcostaParedes

项目描述 :
Google Cloud Spanner ORM + Query Builder for PHP
高级语言: PHP
项目地址: git://github.com/mgcostaParedes/spanner-orm-builder.git
创建时间: 2021-05-07T11:18:38Z
项目社区:https://github.com/mgcostaParedes/spanner-orm-builder

开源协议:MIT License

下载


Spanner ORM Builder For PHP

License
Actions Status
codecov
Total Downloads

The Spanner ORM Builder is a database toolkit to PHP, providing an expressive query builder, ActiveRecord style ORM, it can serve as a database layer for your PHP app if you intend to work with Google Cloud Spanner.

Install

Via Composer

  1. $ composer require mgcosta/spanner-orm-builder

Usage Instructions

First, we should create a new “Manager” instance. Manager aims to make configuring the library for every framework as easy as possible.

  1. use MgCosta\Spanner\Manager;
  2. use Google\Cloud\Spanner\Database;
  3. // $database = your database instance for google cloud spanner;
  4. // instance of Google\Cloud\Spanner\Database;
  5. $manager = new Manager($database);
  6. $manager->boot();

That’s it, you’re ready to use the library, just be sure to instantiate the manager as soon as possible on your APP, usually on your bootstrap or config file.

Once the Manager instance has been registered, we may use it like:

Using The Query Builder

  1. use MgCosta\Spanner\Model\Model;
  2. class User extends Model {}
  3. $users = User::where('age', '>', 30)->get();
  4. $id = 1;
  5. $user = User::find($id);

Updating/Deleting using the Query Builder

  1. use MgCosta\Spanner\Model\Model;
  2. class User extends Model {}
  3. // deleting
  4. User::where('id', 1)->delete();
  5. // updating
  6. $status = User::where('id', 5)->update(['name' => 'Richard', 'age' => 30]);

Saving a model

  1. use MgCosta\Spanner\Model\Model;
  2. class User extends Model {
  3. protected $primaryKey = 'userId';
  4. // available strategies [uuid4, increment]
  5. // increment is not recommend by cloud spanner
  6. protected $keyStrategy = 'uuid4';
  7. // we must define the properties which corresponds to the columns of the table as public
  8. public $userId;
  9. public $name;
  10. public $age;
  11. public $email;
  12. }
  13. $user = new User();
  14. $user->name = 'Miguel';
  15. $user->age = 28;
  16. $user->email = 'email@gmail.com';
  17. $user->save();

Using the query builder without Model Class

  1. use MgCosta\Spanner\Facade\SpannerDB;
  2. (new SpannerDB())->table('users')->whereIn('id', [1, 2, 3])->get();
  3. // you can also provide a custom spanner Database Instance
  4. // $database = instance of Google\Cloud\Spanner\Database;
  5. (new SpannerDB($database))->table('users')->where('id', 1)->first();

The implementation of the query builder is inspired on Laravel Query Builder, to get more documentation follow the link.

Roadmap

You can get more details of the plans for this early version on the following link.

Contributing

Please see CONTRIBUTING for details.

Credits

License

The MIT License (MIT). Please see License File for more information.