”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 访问类中的数据库对象时如何避免全局变量?

访问类中的数据库对象时如何避免全局变量?

发布于2024-12-21
浏览:587

How to Avoid Global Variables When Accessing a Database Object within a Class?

在类中使用全局变量

创建分页功能涉及从类中访问数据库对象。但是,尝试访问类内部的外部变量可能会导致错误。让我们深入研究处理此问题的可能解决方案。

为了解决致命错误“在非对象上调用成员函数 query()”,数据库对象需要在类中可访问。不使用全局变量,更合适的方法是将数据库对象注入到类或其方法中。

依赖注入

一种方法是注入数据库对象放入类构造函数中,如下所示:

include_once("pagi.php");

$db = new DB_MySQL("localhost", "root", "", "test"); // connect to the database

$pagination = new Paginator($db);
$records = $pagination->get_records("SELECT * FROM `table`");

class Paginator
{    
    protected $db;

    public function __construct(DB_MySQL $db)
    {
        $this->db = $db;
    }

    public function get_records($q) {
        $x = $this->db->query($q);
        return $this->db->fetch($x);
    }
}

这允许分页类直接访问数据库对象。

方法注入

另一个选项是将数据库对象注入到特定的需要它的方法:

$pagination = new Paginator();
$records = $pagination->get_records("SELECT * FROM `table`", $db);

class Paginator
{
    public function get_records($q, DB_MySQL $db) {
        $x = $db->query($q);
        return $db->fetch($x);
    }
}

当多种方法具有不同的数据库要求时,这提供了更大的灵活性。

依赖注入的好处

与使用全局变量相比,依赖注入提供了几个优点:

  • 显式定义的依赖关系:它使得它明确哪些对象依赖于其他对象,消除隐藏的依赖关系。
  • 松耦合:该类可以轻松切换到不同或模拟的数据库对象以进行测试。
  • 可测试性:单元测试可以只关注类,而不干扰数据库功能。
  • 扩展性:它允许使用多个数据库或其他框架而无需进行重大代码更改。
最新教程 更多>
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-12-22
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-12-22
  • 为什么“正在加载类 com.mysql.jdbc.Driver...”已被弃用,如何修复它?
    为什么“正在加载类 com.mysql.jdbc.Driver...”已被弃用,如何修复它?
    了解“Loading Class com.mysql.jdbc.Driver ... Is Deprecated”消息尝试连接到 MySQL 时使用旧的驱动类com.mysql.jdbc.Driver的数据库,你可能会遇到一个咨询消息:Loading class com.mysql.jdbc.Dri...
    编程 发布于2024-12-22
  • 除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有什么地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为的主要场景bool:语句:if、whi...
    编程 发布于2024-12-22
  • 如何处理 Java XPath 查询中的 XML 命名空间?
    如何处理 Java XPath 查询中的 XML 命名空间?
    Java XPath 查询中的 XML 命名空间处理在 Java 中,当使用 XPath 查询 XML 时,命名空间可能会带来挑战。当 XML 不包含命名空间时,XPath 查询可以很简单,但命名空间的存在会带来复杂性。情况 1:没有命名空间的 XML对于没有命名空间的 XML,XPath查询使用默...
    编程 发布于2024-12-22
  • Go 1.7 可以在 Windows 上构建 DLL 吗?
    Go 1.7 可以在 Windows 上构建 DLL 吗?
    使用 Go 1.7 构建 dll在本文中,我们将探讨在 Windows 下针对 Go v1.7 构建 dll 的可能性.问题:有没有办法构建一个dll Windows下Go v1.7?背景:尝试使用经典方法构建dll:go build -buildmode=shared main.go导致以下错误:...
    编程 发布于2024-12-22
  • 如何在 PHP 和 MySQL 中有效处理时区?
    如何在 PHP 和 MySQL 中有效处理时区?
    PHP 和 MySQL 中的时区将时区系统集成到 PHP 应用程序中可能具有挑战性,但在处理来自不同数据库的数据时,这一点至关重要时区。这是解决最常见问题并提供实用解决方案的综合指南。在 MySQL 中存储日期时间使用 DATETIME 或 TIMESTAMP: DATETIME 提供更高的精度,而...
    编程 发布于2024-12-22
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-12-22
  • 如何高效检索MySQL数据库中的所有列名?
    如何高效检索MySQL数据库中的所有列名?
    有效获取MySQL中所有表的所有列名无需手动即可高效检索MySQL数据库中所有表的所有列名列出每个表,使用以下 SQL 查询:select column_name from information_schema.columns where table_schema = 'your_db' order...
    编程 发布于2024-12-22
  • 如何用Java将URL内容读入字符串?
    如何用Java将URL内容读入字符串?
    使用 Java 将 URL 内容读入字符串编程中的一个常见需求是检索 URL 的内容并将它们存储为细绳。在 Groovy 中,此任务通过简洁的语法得到简化:String content = "http://www.google.com".toURL().getText();但是,...
    编程 发布于2024-12-22
  • 如何在 C++ 中高效复制向量而不使用循环?
    如何在 C++ 中高效复制向量而不使用循环?
    创建向量副本将向量附加到自身时,出于性能原因,最好避免使用循环。 std::vector::insert 函数虽然是一个选项,但不允许使用迭代器 *this.用 std::copy使用 std::copy 来解决这个问题似乎是一个解决方案,但这种方法可能会导致分段错误。最优解决方案最佳解决方案是同时...
    编程 发布于2024-12-22
  • 使用 Go 标准库构建健壮的 API:综合指南
    使用 Go 标准库构建健壮的 API:综合指南
    作为一名 Go 开发人员,我发现标准库提供了一系列令人印象深刻的工具来构建强大的 API。让我们探索如何利用这些内置包来创建高效且可扩展的 Web 服务。 net/http 包构成了我们 API 开发的基础。它提供了一个简单但功能强大的接口来处理 HTTP 请求和响应。以下是我们如何设置基本服务器:...
    编程 发布于2024-12-22
  • 如何在 CSS 中创建反向边框半径效果?
    如何在 CSS 中创建反向边框半径效果?
    创建倒置边框半径效果问题:可以倒置边框半径吗达到拐角处出现弯曲的效果向内?答案:原生 CSS 的 border-radius 属性不允许使用负值,否则会导致反向效果。不过,这里有一种使用 CSS 的替代方法:在容器内添加四个附加元素,确保它们稍微超出其边界。这些元素应该与页面的背景颜色相匹配,从而产...
    编程 发布于2024-12-22
  • MySQL 可以复制 SQL Server 的链接服务器功能吗?
    MySQL 可以复制 SQL Server 的链接服务器功能吗?
    在 MySQL 中模拟 SQL Server 的链接服务器功能MySQL 可以用来提供类似于 SQL Server 链接服务器的功能吗?如果是这样,如何在 MySQL 5.5 的环境中实现这一点?解决方案虽然 SQL Server 的链接服务器允许与不同数据库进行互操作,但 MySQL 的 FEDE...
    编程 发布于2024-12-22
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-12-22

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3