richbuilds/orm 问题修复 & 功能扩展

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

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

richbuilds/orm

Composer 安装命令:

composer create-project richbuilds/orm

包简介

A wireless ORM for PHP

README 文档

README

RichBuilds Components

🔗 ORM

A wireless, typesafe ORM for PHP 8.1.

Currently only MySql data sources are supported, but Sqlite and Postgres are planned.

The ORM takes all it's instruction from the database. Make sure your primary and foreign keys are set up correctly.

Example usage:

$orm = new Orm(new PDO('dsn','username','password'));

Model

  • represent a row in a table

Create an empty model

  • fails if table doesn't exist
$post = $orm->Model('posts');  

Set a column value

  • fails if column doesn't exit
  • fails if value is not a compatible datatype for the column
$post->set('title', 'My Post Title'); 

Set multiple column values

  • no columns are changed if any fail
$post->set([
    'title'='My Post Title',
    'body'=>'My post body.',
    'created'=>new Datetime()
]);

Set a foreign key column to an existing record

  • fails if the parent record doesn't exist
$post->set('author_id', 1); 

Set a foreign key column to a new Model

  • fails if Model is not of correct type
$user = $orm->Model('user');
$post->set('author_id', $user);

Set a foreign key column to n array of parent model values

$user = ['name'=>'foo','password'=>'password'];
$post->set('author_id', $user);

Set the children of a model

  • accepts arrays of fields or models
$user->set('comments',[
    ['comment'=>'foo', 'visible'=>false],
    $orm->Model('comments')->set('comment', 'bar')
]);

Save the model, it's parents and it's children

  • inside transaction, rolls back on error
  • all keys are updated
$post->save();
echo $post->getPk();

Fetch a parent model

  • fails if column name is not a foreign key or parent doesn't exist
$author = $post->fetchParent('author_id');
// SELECT * FROM users WHERE users.id = posts.author_id
echo $author->get('name');

Fetch children lazily

  • fails if child table name is not a child of the parent
$posts = $user->fetchChildrent('posts');
// SELECT * FROM posts WHERE posts.author_id = user.id

Query

Create a query

$posts = $orm->Query('posts', 
    [
        'author_id'=>1
    ],
    [
        'per_page'=>10
    ]
)

// SELECT * FROM database.posts WHERE database.posts.author_id = :1 LIMIT 10 OFFSET 0;

foreach($posts as $post) {
  echo $post->get('title');
  $comments = $post->fetchChildren('comments');
}

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-05-24