- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我只在屏幕上看到“已连接”,而没有看到其他内容。如何在屏幕上显示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();
}
$conn
设置为false,将
$host
设置为'localhost',等等。然后运行
connect()
函数(您可以跳到该位以查看其作用)
__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);
}
}
pg_close()
用于postgreSQL。我相信您想要的是
mysql_close()
。
$bdd = new db()
创建对象时,将调用构造函数,正如我们之前建立的那样,该构造函数将调用connect方法,该方法在建立连接时会回显“ connected”,因此很容易被回显。但是要显示结果,您需要调用
selectData()
方法,您可以使用
->
运算符(例如
$bdd->selectData()
)进行调用。
关于php - PHP和Mysql面向对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35368376/
我正在创建一个多区域 AlwaysOn Sql Availability 组。我在东部有 2 个虚拟机,在西部有 1 个虚拟机。我需要使用面向公众的负载平衡器对这些进行负载平衡。是否可以使用存在于不同
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是 Smalltalk 技术的新手。我的编程经验是使用 C 和 C++。我想了解smalltalk的设计方法论。谁能推荐一些用smalltalk开发的简单的实时应用程序,可以帮助像我这样的初学者探索
现在我已经对 web2py 比较熟悉了,我想试试 Django。 主要区别是什么? 考虑到 web2py 知识,最有效的入门方法是什么? (一定有一些python应用框架的知识,不是吗?) 编辑 另外
我之前发过一个问题,Moving away from VSS ,其中我向使用 VSS 的 Delphi 开发人员询问了最佳的 VCS 控件。大多数开发人员似乎将 svn 与 TortoiseSVN 一
引用this question ,收集对 Delphi 初学者真正有帮助的网站链接可能会很好。 第一个答案指向Delphi Basics ,这是一个非常好的网站。 但一定还有更多。 所以:请为这个社区
我已经构建了一个 saas 产品,其中 Angular 4 与 golang Rest api 集成,并将构建上传到了 aws ec2 实例上。我的项目是一个基于 Multi-Tenancy 的应用程
我是 .NET 开发人员,在此之前使用过 VB6。我已经非常熟悉这些环境,并在垃圾收集语言的上下文中工作。但是,我现在希望通过 native C++ 增强我的技能,但发现自己有点不知所措。具有讽刺意味
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
由于我在数学方面没有任何出色的技能,所以我问您是否存在我应该在未来可能会改变的类(class)中使用的算法。 考虑以下场景: “角色”类具有以下字段: private boolean admin; p
我有许多面向“列”的 csv 文件,我需要对其进行预处理才能最终索引它们。 这是面向时间的数据,每个“设备”都有大量的列(最多 128 列),例如: LDEV_XXXXXX.csv
我想就重构技巧的最佳资源展开讨论,着眼于前端 JavaScript 重构。 一个我尊重其意见的 friend 建议这个 book ,尽管它使用 Java 中的示例。我明白 OO 重构的原则应该翻译成另
我不明白如何使用 Jquery/javascript 处理对象。 以及如何创建私有(private)方法/变量?我在论坛上看到关闭,但我尝试过但没有用。以及如何查看方法/变量是否是私有(private
我已经使用 MATLAB 多年并且非常熟练。我习惯了 MATLAB 调试,您可以在其中跳过行并查看变量及其变化方式,这就是我学习编码的方式。我现在正在研究使用 FORTRAN、C++ 和 Python
我正在学习如何实现“单一 Activity - 多个 fragment ”架构。据我所知,这是如今很普遍的方法,你可以找到很多关于这个主题的文章。例如这个 http://vinsol.com/blog
目前是否有任何简单的方法可以在 Apache Tomcat Servlet 容器前面设置 YAWS Web 服务器,类似于流行的 Apache httpd + Tomcat 设置? 最佳答案 我不相信
我是一个相当有能力的 Ruby 脚本编写者/程序员,但一直感到要扩展到 C++ 的压力。我没能找到任何与“C++ for Ruby Programmers”相关的网站。 This site Pytho
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我在表上有一个名为 cart_product_fti 的全文索引 每当我使用它时,我都必须准确列出索引中的所有字段: MATCH (foo,bar,etc) 我的想法是,如果稍后我决定向索引添加/删除
我是一名优秀的程序员,十分优秀!