- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个 php 代码来填充一个表,其中一些数据进入 mysl 数据库,但是当我执行时它说
"Fatal error: Call to undefined method MysqlClass::query()"
<?php
include "config.php";
$data = new Mysqlclass();
$data->connetti();
$post_sql = $data->query("SELECT * FROM products ORDER BY id DESC");
if(mysql_num_rows($post_sql) > 0)
{while($post_obj = $Data->estrai($post_sql))
{$id=$post_obj->id;
$name = stripcslashes($post_obj->name);
$cat = stripcslashes($post_obj->category);
$price= stripcslashes($post_obj->price);
echo "<td>".$id."</td>";
echo "<td>".$name."</td>";
echo "<td>".$cat."</td>";
echo "<td>".$price."</td>";
}
}else{
echo"Tabella vuota";
}
$data->disconnetti();
?>
当我声明$Data->query
时,错误出现在第2行。
也许函数查询不正确,我是 PHP 脚本新手。
我在教程中使用了这段代码。我不知道“query”和“estrai”(提取)键是否正确。
这是配置文件:
<?php
class MysqlClass
{
private $nomehost = "localhost";
private $nomeuser = "root";
private $password = "xxxxx";
private $nomedb = "intse";
private $attiva = false;
public function connetti()
{
if(!$this->attiva)
{
if($connessione = mysql_connect($this->nomehost,$this->nomeuser,$this->password) or die (mysql_error()))
{
$selezione = mysql_select_db($this->nomedb,$connessione) or die (mysql_error());
}
} else{
return true;
}
}
public function disconnetti()
{
if($this->attiva)
{
if(mysql_close())
{
$this->attiva = false;
return true;
} else {
return false;
}
}
}
}
?>
http://imageshack.com/a/img35/1966/pd0v.png所以现在我必须用数据库第二个条目填充 row2,用数据库第三个条目填充 row3,并增加 html 中的表行数以填充其他数据库条目。谢谢。
最佳答案
变量区分大小写,($Data->estrai);
使用$data->query将使用MysqlClass类中的查询方法,而不是系统预定义的方法,您需要为其编写一个。如果您想使用类中的方法,例如 $data->method(),则需要在类中构建它。例如
public function query($sql) {
return mysql_query($sql);
}
此外,我看不到 $this->attiva 的用法,因为您没有在某处将其设置为 TRUE。$selezione 也没用。
更新:
mysql_select_db 仅返回一个 bool 值,除了报告失败选择(死亡)之外,您不需要它。
它应该是这样的(如果我没有犯任何语法错误..):
<?php
include 'config.php';
$data = new MysqlClass();
$data->connetti();
$post_sql = $data->query("SELECT * FROM products ORDER BY id DESC");
if(mysql_num_rows($post_sql) > 0) {
while($post_obj = $data->estrai($post_sql)) {
// the data it returns is an array, not object
// so it should be $post_obj['key'] not $post_obj->key
$id = $post_obj['id'];
$name = stripcslashes($post_obj['name']);
$cat = stripcslashes($post_obj['category']);
$price = stripcslashes($post_obj['price']);
echo "<td>".$id."</td>";
echo "<td>".$name."</td>";
echo "<td>".$cat."</td>";
echo "<td>".$price."</td>";
}
} else {
echo 'Tabella vuota';
}
$data->disconnetti();
?>
.
<?php
class MysqlClass {
private $nomehost = 'localhost';
private $nomeuser = 'root';
private $password = 'xxxxx';
private $nomedb = 'intse';
private $attiva = FALSE;
private $connessione;
public function connetti() {
if(!$this->attiva && ($this->connessione = mysql_connect($this->nomehost, $this->nomeuser, $this->password) or die(mysql_error()))) {
mysql_select_db($this->nomedb, $this->connessione) or die(mysql_error());
$this->attiva = TRUE; // Now this becomes useful, because the value has been set
}
return $this->attiva;
}
// Method to build up the query
public function query($sql) {
return mysql_query($sql, $this->connessione);
}
// Method to extract information from the query
public function estrai($query) {
return mysql_fetch_array($query, MYSQL_ASSOC);
}
public function disconnetti() {
// More straight forward way to return the status
if($this->attiva) return mysql_close($this->connessione);
return FALSE;
}
}
更新2:
<?php
include 'config.php';
$data = new MysqlClass();
$data->connetti();
$post_sql = $data->query("SELECT * FROM products ORDER BY id DESC");
echo '<table>';
if(mysql_num_rows($post_sql) > 0) {
while($post_obj = $data->estrai($post_sql)) {
// the data it returns is an array, not object
// so it should be $post_obj['key'] not $post_obj->key
$id = $post_obj['id'];
$name = stripcslashes($post_obj['name']);
$cat = stripcslashes($post_obj['category']);
$price = stripcslashes($post_obj['price']);
echo '<tr>';
echo "<td>".$id."</td>";
echo "<td>".$name."</td>";
echo "<td>".$cat."</td>";
echo "<td>".$price."</td>";
echo '</tr>';
}
} else {
echo 'Tabella vuota';
}
echo '</table>';
$data->disconnetti();
?>
关于php mysql 查询 fatal error ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22812464/
reqwest v0.9 将 serde v1.0 作为依赖项,因此实现 converting serde_json errors into reqwest error . 在我的代码中,我使用 se
我有这个代码: let file = FileStorage { // ... }; file.write("Test", bytes.as_ref()) .map_err(|e| Mu
我只是尝试用angular-cli创建一个新项目,然后运行服务器,但是它停止并显示一条有趣的消息:Error: No errors。 我以这种方式更新了(希望有帮助):npm uninstall -g
我从我的 javascript 发送交易 Metamask 打开传输对话框 我确定 i get an error message in metamask (inpage.js:1 MetaMask -
这个问题在这里已经有了答案: How do you define custom `Error` types in Rust? (3 个答案) How to get a reference to a
我想知道两者之间有什么大的区别 if let error = error{} vs if error != nil?或者只是人们的不同之处,比如他们如何用代码表达自己? 例如,如果我使用这段代码: u
当我尝试发送超过 50KB 的图像时,我在 Blazor 服务器应用程序上收到以下错误消息 Error: Connection disconnected with error 'Error: Serv
我有一个error-page指令,它将所有异常重定向到错误显示页面 我的web.xml: [...] java.lang.Exception /vi
我有这样的对象: address: { "phone" : 888, "value" : 12 } 在 WHERE 中我需要通过 address.value 查找对象,但是在 SQL 中有函数
每次我尝试编译我的代码时,我都会遇到大量错误。这不是我的代码的问题,因为它在另一台计算机上工作得很好。我尝试重新安装和修复,但这没有帮助。这是整个错误消息: 1>------ Build starte
在我的代码的类部分,如果我写一个错误,则在不应该的情况下,将有几行报告为错误。我将'| error'放在可以从错误中恢复的良好/安全位置,但是我认为它没有使用它。也许它试图在某个地方恢复中间表情? 有
我遇到了 csv 输入文件整体读取故障的问题,我可以通过在 read_csv 函数中添加 "error_bad_lines=False" 来删除这些问题来解决这个问题。 但是我需要报告这些造成问题的文
在 Spring 中,验证后我们在 controller 中得到一个 BindingResult 对象。 很简单,如果我收到验证错误,我想重新显示我的表单,并在每个受影响的字段上方显示错误消息。 因此
我不知道出了什么问题,因为我用 Java 编程了大约一年,从来没有遇到过这个错误。在一分钟前在 Eclipse 中编译和运行工作,现在我得到这个错误: #A fatal error has been
SELECT to_char(messages. TIME, 'YYYY/MM/DD') AS FullDate, to_char(messages. TIME, 'MM/DD
我收到这些错误: AnonymousPath\Anonymized.vb : error BC30037: Character is not valid. AnonymousPath\Anonymiz
我刚刚安装了 gridengine 并在执行 qstat 时出现错误: error: commlib error: got select error (Connection refused) erro
嗨,我正在学习 PHP,我从 CRUD 系统开始,我在 Windows 上安装了 WAMP 服务器,当我运行它时,我收到以下错误消息。 SCREAM: Error suppression ignore
我刚刚开始一个新项目,我正在学习核心数据教程,可以找到:https://www.youtube.com/watch?v=zZJpsszfTHM 我似乎无法弄清楚为什么会抛出此错误。我有一个名为“Exp
当我使用 Jenkins 运行新构建时,出现以下错误: "FilePathY\XXX.cpp : fatal error C1853: 'FilePathZ\XXX.pch' precompiled
我是一名优秀的程序员,十分优秀!