php查询类,PHP的回声查询结果在类?

我有一个关于PHP类的问题.我正在尝试通过PHP从Mysql获取结果.我想知道最佳实践是在类中显示结果还是将结果存储并以html处理.

例如,在班级内部显示结果

class Schedule {

public $currentWeek;

function teamQuery($currentWeek){

$this->currentWeek=$currentWeek;

}

function getSchedule(){

$connection = mysql_connect(DB_SERVER,DB_USER,DB_PASS);

if (!$connection) {

die("Database connection failed: " . mysql_error());

}

$db_select = mysql_select_db(DB_NAME,$connection);

if (!$db_select) {

die("Database selection failed: " . mysql_error());

}

$scheduleQuery=mysql_query("SELECT guest, home, time, winner, pickEnable FROM $this->currentWeek ORDER BY time", $connection);

if (!$scheduleQuery){

die("database has errors: ".mysql_error());

}

while($row=mysql_fetch_array($scheduleQuery, MYSQL_NUMS)){

//display the result..ex: echo $row['winner'];

}

mysql_close($scheduleQuery);

//no returns

}

}

或者将查询结果作为变量返回并在php中处理

class Schedule {

public $currentWeek;

function teamQuery($currentWeek){

$this->currentWeek=$currentWeek;

}

function getSchedule(){

$connection = mysql_connect(DB_SERVER,DB_USER,DB_PASS);

if (!$connection) {

die("Database connection failed: " . mysql_error());

}

$db_select = mysql_select_db(DB_NAME,$connection);

if (!$db_select) {

die("Database selection failed: " . mysql_error());

}

$scheduleQuery=mysql_query("SELECT guest, home, time, winner, pickEnable FROM $this->currentWeek ORDER BY time", $connection);

if (!$scheduleQuery){

die("database has errors: ".mysql_error());

// create an array }

$ret = array();

while($row=mysql_fetch_array($scheduleQuery, MYSQL_NUMS)){

$ret[]=$row;

}

mysql_close($scheduleQuery);

return $ret; // and handle the return value in php

}

}

这里有两件事:

>我发现php中的返回变量有点复杂,因为它是二维数组.我不确定最佳做法是什么,想问一下专家的意见.

>每次创建新方法时,都必须重新创建$connection变量:请参见下文

$connection = mysql_connect(DB_SERVER,DB_USER,DB_PASS);

如果(!$connection){

die(“数据库连接失败:”.mysql_error());

}

$db_select = mysql_select_db(DB_NAME,$connection);

if (!$db_select) {

die("Database selection failed: " . mysql_error());

}

对我来说似乎多余.我可以只执行一次,而不必在需要查询时调用它吗?我是php类的新手.希望你们能帮助我.谢谢.

解决方法:

我将此类视为“访问器”,因此它们仅查询数据库并返回结果.这样,任何调用它的PHP代码都可以使用它来完成自己喜欢的事情.这可能正在显示,或者可能是检查,也可能是更新.这是一个很好的设计,因为它将数据存储区与逻辑与显示区分开,这意味着您的代码将更加灵活.但是是的,它有点复杂.

关于每次重新创建连接.这可能是必需的,也可能不是必需的.根据您的设置,您可能可以创建连接池.为了使您现在更轻松,您可以将连接的创建抽象为自己的方法.这样,您只需要在开始时调用此方法即可获得连接句柄.这样可避免您到处都有许多相同代码的副本.

如果您不熟悉PHP类,建议您对面向对象的设计进行一些研究.这将使您了解为什么抽象一些函数会有所好处,以及为什么要返回结果而不是显示结果.

标签:php,class

来源: https://codeday.me/bug/20191210/2098742.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值