gpt4 book ai didi

php - PHP和Mysql面向对象

转载 作者:行者123 更新时间:2023-11-29 07:23:14 27 4
gpt4 key购买 nike

我只在屏幕上看到“已连接”,而没有看到其他内容。如何在屏幕上显示mysql表行?

<?php
class db {
private $conn;
private $host;
private $user;
private $password;
private $baseName;
private $port;

function __construct($params=array()) {
$this->conn = false;
$this->host = 'localhost'; //hostname
$this->user = 'fp0313'; //username
$this->password = ''; //password
$this->baseName = 'test'; //name of your database
$this->port = '3306';
$this->connect();
}

function __destruct() {
$this->disconnect();
}

function connect() {
if (!$this->conn) {
$this->conn = mysql_connect($this->host, $this->user, $this->password);
mysql_select_db($this->baseName, $this->conn);

if (!$this->conn) {
$this->status_fatal = true;
echo 'Connection BDD failed';
die();
}
else {
$this->status_fatal = false;
echo 'Connected';
}
}

return $this->conn;
}

function selectData()
{
$User = $bdd->getOne('SELECT stud_id, stud_voornaam, stud_achternaam FROM student'); // 1 line selection, return 1 line
echo $User['stud_id'].'<br>'; // display the id
echo $User['stud_voornaam'].'<br>'; // display the first name
echo $User['stud_achternaam']; // display the last name
}


function disconnect() {
if ($this->conn) {
@pg_close($this->conn);
}
}
}
$bdd = new db(); // create a new object, class db()
?>

最佳答案

似乎您不太了解PHP类的工作原理,所以我将向您介绍OOP PHP的基础知识。完整的答案太长,无法发布为答案,因此,我仅作了简短介绍,并链接到更详细的说明:)

物产

属性本质上是与对象实例相关联的变量。也可以有与类关联的静态属性。可以将属性声明为公共,私有或受保护。 Read more...

方法

与属性类似,方法与类实例或类本身相关联,方法只是属于类的一部分的函数。方法也可以是静态的,也可以声明为公共,私有或受保护。与上述相同的链接适用于此。

魔术方法

PHP有一些“魔术方法”。这些只是为特殊功能保留的方法的名称。例如,__construct是一种魔术方法,该方法在初始化对象时运行。 __clone也是一种魔术方法,在克隆对象时运行。要定义其中之一,您只需定义一个与magic方法同名的方法,该方法将在特定点运行,例如__construct;创建对象时,对于__clone方法,将在克隆对象时运行它。此外,仅需注意-无需定义所有魔术方法,只需定义希望使用的方法即可。 Read more...

与OOP PHP重要部分相关的其他链接,这些链接与您的情况不太相关,但是仍然需要了解


Extending classses
Class Abstraction
Object Interfaces
Object Serialization


在上下文中

因此,现在您了解了OOP PHP的基本知识,让我们深入探讨问题中提供的类的功能!

首先让我们看一下这一部分:

private $conn;
private $host;
private $user;
private $password;
private $baseName;
private $port;


这将声明所有属性。 private意味着这些属性仅可用于此类,而不能用于任何扩展类(请参见上面有关扩展类的链接)。

现在让我们看一下:

function __construct($params=array()) {
$this->conn = false;
$this->host = 'localhost'; //hostname
$this->user = 'fp0313'; //username
$this->password = ''; //password
$this->baseName = 'test'; //name of your database
$this->port = '3306';
$this->connect();
}


这不带任何参数。您可以传入一个参数,但不会使用该参数,如果不传入任何参数,则将为变量$ params分配一个空数组,该变量仅具有局部作用域,因为它是函数的一部分。

如您所知,此函数将在创建对象时执行,因此会为某些属性分配值。它将 $conn设置为false,将 $host设置为'localhost',等等。然后运行 connect()函数(您可以跳到该位以查看其作用)

现在让我们来看一下:
    函数__destruct(){
        $ this-> disconnect();
    }
这定义了 __destruct魔术方法,该方法在对象被销毁时运行,通常发生在脚本末尾。在这种情况下,该函数仅运行 disconnect()函数,我们将在后面介绍。

现在这部分:

function connect() {
if (!$this->conn) {
$this->conn = mysql_connect($this->host, $this->user, $this->password);
mysql_select_db($this->baseName, $this->conn);

if (!$this->conn) {
$this->status_fatal = true;
echo 'Connection BDD failed';
die();
}
else {
$this->status_fatal = false;
echo 'Connected';
}
}

return $this->conn;
}


这首先检查 $conn是否设置为false(它使用 !(不是)运算符将其取反,因此,如果 $conn的反数为true,则条件的值为true)。在这种情况下,尚无数据库连接,因此它将使用 mysql_connect()创建一个数据库连接,并将该连接分配给 $conn属性。然后选择数据库。然后检查以确保连接成功。如果不是,则将 $status_fatal属性设置为 true,回显“连接BDD失败”,并使用 die停止执行,如果连接成功,则将 $status_fatal属性设置为 false,并回显单词“ Connected”。这就是您目前所看到的。然后,该函数返回 $conn属性。

正如有人在您的问题注释中指出的那样,您可能希望在建立连接成功之后选择数据库,因为这意味着在连接失败时您将不会尝试选择数据库。

现在让我们看一下这一部分:

    function selectData()
{
$User = $bdd->getOne('SELECT stud_id, stud_voornaam, stud_achternaam FROM student'); // 1 line selection, return 1 line
echo $User['stud_id'].'<br>'; // display the id
echo $User['stud_voornaam'].'<br>'; // display the first name
echo $User['stud_achternaam']; // display the last name
}


这种方法实际上存在错误。由于这是在函数中,因此所有变量都具有局部作用域,并且要定位类的属性,您需要引用 $this。因此,当您使用 $bdd时,它假定在该本地范围内有这样一个变量,因此您需要将其作为参数传递给函数。

假设您现在已解决该错误,并以对象作为参数传递,则该对象的方法 GetOne将运行。我不能告诉你这是做什么的,因为我现在知道 $dbb对象包含的内容。在不知情的情况下很难解释会发生什么,所以我想我会在没有该对象的情况下重写类似的内容。您应该能够弄清楚如何使其适应您的情况。这是使用mysql查询的工作方式(注意:我正在使用mysqli,这是您应该使用的,因为mysql_ *函数现在已过时。):

function SelectData() {
$result = mysqli_query($this->conn, "SELECT stud_id, stud_voornaam, stud_achternaam FROM student LIMIT 1");
$user = mysqli_fetch_assoc($result);

echo $user['stud_id'] . "<br />\r\n";
echo $user['stud_voornaam'] . "<br />\r\n";
echo $user['stud_achternaam'];
}


这引用了先前在 mysqli_query()方法中建立的连接,该连接查询数据库。然后将结果存储在 $result变量中。然后使用 mysqli_fetch_assoc()将结果集转换为关联数组,然后将其回显。您对象中的函数可能会执行类似的操作。

现在让我们看一下这一部分:

function disconnect() {
if ($this->conn) {
@pg_close($this->conn);
}
}


这将关闭数据库连接。我相信这是一个错误,但是,因为您先前已经创建了mysql数据库连接,但是 pg_close()用于postgreSQL。我相信您想要的是 mysql_close()

“好吧...但是我仍然得到相同的结果”

当您使用 $bdd = new db()创建对象时,将调用构造函数,正如我们之前建立的那样,该构造函数将调用connect方法,该方法在建立连接时会回显“ connected”,因此很容易被回显。但是要显示结果,您需要调用 selectData()方法,您可以使用 ->运算符(例如 $bdd->selectData())进行调用。



我尝试详细解释了所有内容,但如果您不了解某些内容,请随时进行澄清。

关于php - PHP和Mysql面向对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35368376/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com