在PHP编程中,访问MySQL数据库是一项常见的操作,为了提高代码的可维护性和重用性,通常会将数据库访问的相关功能进行封装,形成一个独立的类,本文将详细解释如何创建一个基于PHP和MySQL的数据库访问封装类,适用于PHP4和PHP5,支持mysql_和mysqli_两种方式。

连接数据库
1. 使用mysql_connect或mysqli_connect
mysql_connect: 用于连接到MySQL服务器。
mysqli_connect: 是面向对象的连接方式。
2. 示例代码
class MySQLDB {
private $connection;
public function __construct($server, $username, $password) {
if (function_exists('mysqli_connect')) {
$this->connection = mysqli_connect($server, $username, $password);
} else {
$this->connection = mysql_connect($server, $username, $password);
}
if (!$this->connection) {
die('Connection failed: ' . mysqli_connect_error());
}
}
}
选择数据库
1. 使用mysql_select_db或mysqli_select_db
mysql_select_db: 用于选择MySQL数据库。
mysqli_select_db: 是面向对象的选择数据库方式。
2. 示例代码
public function selectDatabase($database) {
if (function_exists('mysqli_select_db')) {
$result = mysqli_select_db($this->connection, $database);
} else {
$result = mysql_select_db($database, $this->connection);
}
if (!$result) {
die('Select database failed: ' . mysqli_connect_error());
}
}
执行SQL查询
1. 使用mysql_query或mysqli_query
mysql_query: 用于执行SQL查询。
mysqli_query: 是面向对象的查询方式。

2. 示例代码
public function query($sql) {
if (function_exists('mysqli_query')) {
$result = mysqli_query($this->connection, $sql);
} else {
$result = mysql_query($sql, $this->connection);
}
if (!$result) {
die('Query failed: ' . mysqli_connect_error());
}
return $result;
}
处理查询结果
1. 使用mysql_fetch_assoc或mysqli_fetch_assoc
mysql_fetch_assoc: 用于获取结果集中的下一行作为关联数组。
mysqli_fetch_assoc: 是面向对象的获取结果集方式。
2. 示例代码
public function fetchAssoc($result) {
if (function_exists('mysqli_fetch_assoc')) {
return mysqli_fetch_assoc($result);
} else {
return mysql_fetch_assoc($result);
}
}
相关问题与解答
问题1:如何在PHP中使用PDO(PHP Data Objects)来访问MySQL数据库?
解答:PDO是一种在PHP中访问数据库的方式,它提供了一种统一的方式来处理不同的数据库,以下是一个简单的PDO连接MySQL的例子:
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";
try {
$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
echo "Connected successfully";
} catch(PDOException $e) {
echo "Connection failed: " . $e->getMessage();
}
?>
问题2:在PHP中,如何处理MySQL的错误信息?
解答:在PHP中,可以使用mysqli_connect_error()函数来获取最后一次MySQL操作的错误信息。
<?php
$link = mysqli_connect("localhost", "my_user", "my_password", "my_db");
if (!$link) {
echo "Error: Unable to connect to MySQL." . PHP_EOL;
echo "Debugging errno: " . mysqli_connect_errno() . PHP_EOL;
echo "Debugging error: " . mysqli_connect_error() . PHP_EOL;
exit;
}
echo "Success: Connected to MySQL!" . PHP_EOL;
...
?>
以上就是关于“PHP访问MYSQL数据库封装类(附函数说明)-PHPphp技巧”的问题,朋友们可以点击主页了解更多内容,希望可以够帮助大家!