承接 yii1x/active-record 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

yii1x/active-record

最新稳定版本:0.1.0

Composer 安装命令:

composer require yii1x/active-record

包简介

Yii 1.1 Active Record, extracted and modernized for PHP 8.4+

README 文档

README

Yii 1.1 Active Record, extracted and modernized for PHP 8.4+.

Familiar API. Zero framework lock-in.

Packagist License

What is it?

This package is the Active Record component from Yii 1.1, extracted and refactored to run on PHP 8.4+ without requiring the full Yii framework.

  • ✅ Same API you know from Yii 1
  • ✅ PHP 8 types and attributes support
  • ✅ No Yii::app() dependency
  • ✅ Works with any PSR-11 compatible container

Requirements

  • PHP ≥ 8.4
  • PSR-11 ContainerInterface (required)
  • Optional PSR dependencies (if used in your app):
    • Psr\Log\LoggerInterface
    • Psr\SimpleCache\CacheInterface
    • Psr\EventDispatcher\EventDispatcherInterface

Installation

composer require yii1x/active-record

Bootstrap

Before using any model, initialize the ORM context once per application lifecycle:

use Yii1x\ActiveRecord\ORMContext;

ORMContext::bootstrap($container, debug: false);

Where $container is your PSR-11 container.

The container must be able to return a configured database connection instance by name (e.g., 'db' or 'yourDbName').

This can be:

  • An instance of Yii1x\ActiveRecord\Db\DbConnection
  • Any class extending DbConnection

Example configuration (from Yii 3):

<?php
return [
    'db_name' => [
        'class' => \Yii1x\ActiveRecord\Db\DbConnection::class,
        '__construct()' => [
            'dsn' => 'mysql:host=db;port=3306;dbname=yii3',
            'username' => 'root',
            'password' => 'root',
            'connectionName' => 'db_name',
        ],
    ],
];

Then in your models, specify which connection to use:

#[Database(name: 'db_name')]
class User extends ActiveRecord
{
    // ...
}

Define a Model

Use PHP 8 attributes instead of class properties:

use Yii1x\ActiveRecord\ActiveRecord;
use Yii1x\ActiveRecord\Attributes\Table;
use Yii1x\ActiveRecord\Attributes\Database;

#[Table(name: 'user')]
#[Database(name: 'db_name')]
class User extends ActiveRecord
{
    public function relations(): array
    {
        return [
            'posts' => [self::HAS_MANY, Post::class, 'user_id'],
        ];
    }
}

Querying (familiar Yii 1 style)

// Find one
$user = User::model()->findByAttributes(['email' => 'test@example.com']);

// new fluent query builder
$users = User::queryBuilder()
    ->where('status', 1)
    ->orderBy('created_at DESC')
    ->limit(10)
    ->with('posts')
    ->findAll();

Framework Agnostic

Works with any PSR-11 container (as shown in the Yii 3 example above).

No Yii framework required. No global state. Just Active Record.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: Unknown
  • 更新时间: 2026-02-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固