定制 phpgt/orm 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

phpgt/orm

Composer 安装命令:

composer require phpgt/orm

包简介

Object relational mapper.

README 文档

README

This repository is currently in a prototype stage. I'm planning on building it out properly, but it may never get completed, or I might change it completely without notice.

Please don't use on anything real until a stable release is made!

Notes

Basic table creation is possible like this:

$generator = new SchemaGenerator();
$studentSchemaTable = $generator->generate(Student::class);

Then the $studentSchemaTable can be passed to the actual underlying database for it to execute as SQL.

For example:

$db->executeSQL($studentSchemaTable);

Here's an example of what the Student class looks like, and how the SchemaGenerator stringifies it as SQLite:

readonly class Student {
	public function __construct(
		public int $id,
		public string $name,
		public DateTime $dob,
	) {}
}
create table `Student` (
	`id` int not null primary key,
	`name` text not null,
	`dob` int not null 
)

Some questions I need to answer before I go any further:

  • How should the DateTime class be cast back and forth between different database engines? MySQL has a datetime type, but SQLite has to use a timestamp.
  • How should the different constraints be handled? I like the idea of adding an attribute to describe the primary key: #[PrimaryKey("id", PrimaryKey::AUTOINCREMENT)]
  • Straight-up foreign keys should be easy to implement - use a class as a public property.
  • A common OOP technique is to have an array/iterable of objects. For example, the Lesson class can have an array<Student> or a custom StudentCollection class.
  • This means a StudentCollection must be a differently derived class than Student, as it represents a junction table.

One big question I have yet to prototype:

  • Cyclic dependencies are OK and sometimes really useful, especially in OOP land, but a recursive SQL query would be really inefficient on big data structures.
  • The foreign key should not be loaded until it's used in code (lazy load), but this is going to require some clever programming for a good developer experience.

I think the way this should work is foreign keys are never done using joins - instead, separate queries should always be used. That way, the query that loads the referenced table will not need to be executed until the developer requests that field.

This could be achieved by the Orm generating an anonymous class that extends the referenced class, but takes on a trait to allow __get to execute the query... something like that, but I expect weird reflection will be required to make this transparent to the developer.

Proudly sponsored by

JetBrains Open Source sponsorship program

JetBrains logo.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-20

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固