stietotalwin/arif-rh-ci4-dynamic-model-extended
最新稳定版本:1.0.0
Composer 安装命令:
composer require stietotalwin/arif-rh-ci4-dynamic-model-extended
包简介
Creating CodeIgniter 4 Model on-the-fly with Relationship Built-in Feature.
关键字:
README 文档
README
Dynamic Model for CodeIgniter 4 Extended by Stie Total Win Forked from Arif RH
================================================================================
Feature
- Dynamically Creating the Model on-the-fly
- Support One-to-One / Many-to-One relationship
- Support One-to-Many relationship
- Can Filter data based on child/related criteria
- Can set the order of One-to-Many relationship result based on child criteria
Installation
composer require stietotalwin/arif-rh-ci4-dynamic-model-extended
Usage
Simple
// creating postModel on-the-fly, just pass a table name $postModel = \StieTotalWin\DynaModel\DB::table('posts'); // then you can use it, to get all posts $postModel->findAll();
Many-to-One Relationship
// assume that posts always belongs to one author using author_id $postModel->belongsTo('authors); // then you can grab author info along with posts $postModel->with('authors')->findAll(); /** * by default, primary key of authors will be omit in the column result * because its value already exist in the foregin key of relationship * * if authors has same column name with posts, then it will be aliased with prefix "author_" * for example, both posts and authors has "rating" column, then it will become author_rating */ // you can call only spesific column if you need, pass it on the second parameters in array $postModel->with('authors', ['name', 'rating'])->findAll(); // will display all posts column, plus author name and author rating // you can filter posts based on author criteria $postModel->with('authors')->whereRelation('authors', ['status' => 'active'])->findAll(); // will display all posts only from active authors
One-to-Many Relationship
$postModel->hasMany('comments'); // this will return posts with all related comments $postModel->with('comments')->findAll(); // you can also filter posts based on comments criteria $postModel->with('comments')->whereRelation('comments', ['status' => 'approved'])->findAll(); // will display all posts with approved comments only
Testing
composer test
// or
composer testdox
// analyse code
composer analyse
统计信息
- 总下载量: 16
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-05-07