首页 > 数据库 > mysql教程 > 如何根据数据库类型动态实例化PHP对象?

如何根据数据库类型动态实例化PHP对象?

Susan Sarandon
发布: 2024-11-24 15:19:11
原创
707 人浏览过

How to Dynamically Instantiate PHP Objects Based on Database Types?

从数据库类型动态实例化 PHP 对象

在 PHP 中,可以基于指定定义类型的字符串动态创建对象在数据库表中。为了实现这一目标,可以利用数据库查询和 PHP 的动态对象创建功能。

考虑一个包含以下列和示例数据的数据库表:

id | type | propertyVal
----+------+-------------
1 | foo  | lorum
2 | bar  | ipsum
登录后复制

假设我们有 PHP 数据类型定义如下:

class ParentClass {...}
class Foo extends ParentClass {private $id, $propertyVal; ...}
class Bar extends ParentClass {private $id, $propertyVal; ...} 
// ...(more classes)...
登录后复制

要创建由数据库类型列定义的类型的对象,我们可以利用以下内容步骤:

  • 执行一个查询,选择具有所需 id 的行。
  • 使用 mysql_fetch_object() 以关联数组的形式检索数据。
  • 获取从关联数组中输入值。
  • 使用以下语法动态创建该类型的对象: $instance = new $type;.
  • 从关联数组中分配对象的剩余属性。

例如:

$result = mysqli_query($conn, "SELECT * FROM table WHERE id = 1");
$row = mysqli_fetch_assoc($result);

$type = $row['type'];
$instance = new $type;

unset($row['type']);  
foreach ($row as $property => $value) {
   $instance->$property = $value;
}
登录后复制

这样的方式,实例对象将使用类型数据库列指定的类型动态创建,并且其属性将被分配所选行中的值。

以上是如何根据数据库类型动态实例化PHP对象?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板