- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
运行时 dbconfig.php
(如下所述)出现错误:
PHP Fatal error: Call to a member function prepare() on a non-object in Class.crud.php on line 13
PHP Stack trace:
PHP 1. {main}() dbconfig.php:0
PHP 2. crud->create() dbconfig.php:16
文件: dbconfig.php
<?php
$db_host = "localhost";
$db_user = "root";
$db_pass = "95111991";
$db_name = "php_pdo_db";
try{
$db_con = new PDO("mysql:host={$db_host}; dbname = {$db_name}",$db_user,$db_pass);
$db_con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
catch (PDOException $e){
echo $e->getMessage();
}
include_once 'Class.crud.php';
$crud = new crud($db_con);
?>
文件: Class.crud.php
<?php
class crud
{
private $db;
function _construct($db_con)
{
$this->db = $db_con;
}
public function create($fname,$lname,$email)
{
try{
$stmt = $this->db->prepare("INSERT INTO tbl_user(Firstname,Lastname,Email) VALUES (:fname,:lname, :email)");
$stmt ->bindparam(":fname", $fname);
$stmt ->bindparam(":lname", $lname);
$stmt ->bindparam(":email", $email);
$stmt->execute();
return true;
}catch (PDOException $e){
echo $e->getMessage();
return false;
}
}
public function getID($id){
$stmt = $this->db->prepare("SELECT * FROM tbl_user WHERE ID = :id");
$stmt->execute(array(":id"=>$id));
$editRow=$stmt->fetch(PDO::FETCH_ASSOC);
return $editRow;
}
public function update($id,$fname,$lname,$email)
{
try{
$stmt=$this->db->prepare("UPDATE tbl_user SET Firstname = :fname,
Lastname = :lname, Email = :email WHERE ID = :id");
$stmt->bindparam(":fname",$fname);
$stmt->bindparam(":lname",$lname);
$stmt->bindparam(":email",$email);
$stmt->bindparam(":id",$id);
$stmt->execute();
return true;
}catch (PDOException $e){
echo $e -> getMessage();
return false;
}
}
public function delete($id)
{
$stmt = $this->db->prepare("DELETE FROM tbl_user WHERE ID = :id");
$stmt->bindparam(":id",$id);
$stmt->execute();
return true;
}
/* paging */
public function dataview($query)
{
//global $db_con
$stmt = $this->db->prepare($query);
$stmt->execute();
if($stmt->rowCount()>0){
while($row=$stmt->fetch(PDO::FETCH_ASSOC))
{
?>
<tr>
<td><?php print($row['ID']); ?></td>
<td><?php print($row['Firstname']); ?></td>
<td><?php print($row['Lastname']); ?></td>
<td><?php print($row['Email']); ?></td>
<td align = "center">
<a href = "edit_data.php?edit_id=<?php print($row['ID']); ?>"><i class = "glyphicon glyphicon-edit"></i></a>
</td>
<td align = "center">
<a href = "delete_data.php?delete_id=<?php print($row['ID']); ?>"><i class = "glyphicon glyphicon-remove-circle"></i></a>
</td>
</tr>
<?php
}
}
else{
?>
<tr>
<td>Nothing here...</td>
</tr>
<?php
}
}
public function paging($query,$records_per_page)
{
$starting_position = 0;
if(isset($_GET["page_no"]))
{
$starting_position = ($_GET["page_no"]-1)*$records_per_page;
}
$query2 = $query." limit $starting_position, $records_per_page";
return $query2;
}
public function paginglink($query,$records_per_page)
{
$self = $_SERVER['PHP_SELF'];
$stmt = $this->db->prepare($query);
$stmt->execute();
$total_no_of_records = $stmt->rowCount();
if($total_no_of_records > 0){
?><ul class = "pagination"><?php
$total_no_of_page = ceil($total_no_of_records/$records_per_page);
$current_page = 1;
if(isset($_GET["page_no"]))
{
$current_page = $_GET["page_no"];
}
if($current_page != 1)
{
$previous = $current_page-1;
echo "<li><a href = '".$self."?page_no=1'>First</a></li>";
echo "<li><a href = '".$self."?page_no=".$previous."'>Previous</a></li>";
}
for($i = 1; $i <= $total_no_of_page; $i++)
{
if($i == $current_page)
{
echo "<li><a href = '".$self."?page_no=".$li."' style = 'color:red;'>".$i."</a></li>";
}
else{
echo "<li><a href = '".$self."?page_no=".$i."'>".$i."</a></li>";
}
}
if($current_page != $total_no_of_page)
{
$next = $current_page+1;
echo "<li><a href = '".$self."?page_no=".$next."'>Next</a></li>";
echo "<li><a href = '".$self."?page_no=".$total_no_of_page."'>Last</a></li>";
}
?></ul><?php
}
}
/* paging */
}
?>
如何解决此错误?
最佳答案
在您的class crud
中,您已经编写了:
function _construct($db_con)
使用__construct
代替_construct
function __construct($db_con)
关于php - PDO : Getting Error : Call to a member function prepare() on a non-object,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42711429/
PHP查询: prepare('SELECT * FROM Locations WHERE user_id = :id LIMIT 0, 5'); $query->bindParam(":id
到目前为止我一直在使用 PDO->bindParam 但是在阅读手册时我发现 PDO->bindValue 我可以告诉 PDO->bindValue 按值传递,而 PDO->bindParam 按引用
我使用PDO进行MySQL数据库连接、选择、更新和删除。 但是我在选择带有特殊字符的行时遇到问题,例如,我想选择带有“Judge-Fürstová Mila”的页面标题, 表页, id titl
我使用的是 PHP 5.2.9 和 Apache 2.2.11 以及 mysql 5.1.32 为什么我不能禁用 PDO::ATTR_EMULATE_PREPARES ? 下面是代码: false)
当 PDO::ATTR_PERSISTENT = true 时,PDO::exec 和 PDO::query 之间似乎存在差异。当使用PDO::exec时,连接将不会被重用,并最终导致MySQL出现“
我正在尝试调整 Zend Skeleton App 以使用 ODBC 连接。我能够在 Zend 之外设置 PDO 连接(同一个表、服务器、所有内容),如下所示: new PDO('odbc:DRIVE
我正在使用 XAMPP 3.2.1 在 Windows 7 上使用 PDO,但在使其正常工作时遇到问题,即使它可以在我的共享托管服务器。 settings.php db.php setAttribu
我正在尝试使用以下代码从 get 变量中获取结果,我使用了另一个代码(在下面列出)并且它有效但是在使用它时无法逃脱,我不知道我有什么做错了,但我需要帮助,我刚刚开始 PDO,所以是的,我是个白痴 :D
我有这个代码 try { $dbh = new PDO('mysql:host=localhost;dbname=db_informations', 'root', ''); $dbh
在我的本地开发机器 (MAMP) 上,我的 MySQL 查询返回正确的大小写。但是,在我的共享托管服务器上,使用 fetch(PDO::FETCH_ASSOC); 时,我的结果是小写的 我试过以下方法
我正在使用这个 PDO 连接: try{ $db=new PDO(" mysql:host=localhost; dbname=...", "dbu...", "pass", array(PDO::M
我需要将 PDO 连接从 controller 传递到 cart 类, function __construct($connection) { $this->cart = new cart($
位于 PHP.net 的 PDO 交易示例表明 PDO::exec() 是事务处理的,但是没有这样的例子使用 PDO::query()。 事务是否涵盖 PDO::query()? 此外,据我所知,PD
几天来我一直在使用来自 http://www.mamp.info 的 MAMP Pro 3.07 . 很棒的工具,一切正常。 但是现在我遇到了问题,对于一个新项目,我需要连接到 MSSQL。 我在 w
我正在尝试在我的 PHP 代码中使用 PDO 模块来连接到数据库。我已经阅读并搜索了类似的主题,但我无法弄清楚我做错了什么。请帮我解决问题。 Apache版本:Apache/2.2.21 (Win32
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我使用 PDO 连接到我的数据库,我不知道哪种方法比更新、删除和插入、PDO::exec 或 PDO::excute 的另一种方法更好。我应该使用哪个? 最佳答案 虽然这两种方法具有相似的命名(exe
如何在 Codeigniter 中设置 PDO 数据库句柄的属性(PDO::ATTR_ERRMODE)? 最佳答案 我认为更好的选择是使用 MY_Model(然后您对其进行扩展,然后它在整个应用程序中
从 mysql 切换到 PDO 我注意到 fetch 方法改变了 PDO 对象本身!例如: $res=$ps->fetchAll(); echo($res[0]['Mail']); //it'ok /
嗨,我正在使用 PDO 为 mysql 开发一个基本的数据库连接类,但是当我 var dump 返回结果时,它告诉我我有 2 个对象:object(PDO)[2]。不应该只有一个吗? 这是迄今为止我的
我是一名优秀的程序员,十分优秀!