TP框架下数据库连接教程 (怎么在tp中连接数据库)
随着互联网技术的不断发展和普及,Web应用程序开发变得越来越重要和复杂。为了简化Web开发和提高开发效率,许多框架应运而生。ThinkPHP(以下简称TP)框架是国内较为流行的Web开发框架之一,它具有高效、简单、灵活的特点,并且拥有强大的扩展机制。在TP框架下,连接数据库是很常见的需求,本文将介绍如何在TP框架下连接数据库。
一、 数据库驱动配置
TP框架默认集成了MySQL、Mysqli、Sqlite、Oracle等数据库驱动,我们只需要在配置文件中配置相关参数即可。打开TP框架的配置文件/config/database.php,对于MySQL数据库连接配置,我们需要设置以下参数:
‘default’ => [
// 数据库类型
‘type’ => ‘mysql’,
// 服务器地址
‘hostname’ => ‘127.0.0.1’,
// 数据库名
‘database’ => ‘test’,
// 用户名
‘username’ => ‘root’,
// 密码
‘password’ => ‘123456’,
// 端口
‘hostport’ => ‘3306’,
// 数据库编码默认采用utf8
‘charset’ => ‘utf8’,
// 数据库表前缀
‘prefix’ => ”,
// 数据库调试模式
‘debug’ => true,
],
其中,hostname表示MySQL服务器地址,database表示连接的数据库名,username和password表示连接的用户名和密码,如果是本地服务器则可以使用默认值,hostport为MySQL端口号,默认是3306,charset表示连接数据库的编码格式,默认为utf8,prefix表示TP框架的数据表名前缀。
二、 数据库连接
在TP框架下,连接数据库的方式有两种:PDO方式和mysqli方式。
1. PDO方式连接数据库
使用PDO方式连接数据库,需要在配置文件中设置正确的数据库连接参数,然后在模型中引用database.php配置文件。
namespace app\index\model;
use think\Model;
class UserModel extends Model
{
protected $name = ‘user’;
public function userList()
{
$db_config = \think\facade\Config::get(‘database’);
$dsn = “{$db_config[‘type’]}:host={$db_config[‘hostname’]};dbname={$db_config[‘database’]};port={$db_config[‘hostport’]};charset={$db_config[‘charset’]}”;
$user = $db_config[‘username’];
$pass = $db_config[‘password’];
$dbh = new \PDO($dsn, $user, $pass);
$sql = ‘SELECT id, user_name FROM think_user’;
$sth = $dbh->prepare($sql);
$sth->execute();
$result = $sth->fetchAll(\PDO::FETCH_ASSOC);
return $result;
}
}
2. mysqli方式连接数据库
使用mysqli方式连接数据库,需要在数据库配置文件中设置参数,默认情况下TP框架会自动引入Mysqli类库,我们只需要在模型中实例化并使用即可。
namespace app\index\model;
use think\Model;
class UserModel extends Model
{
protected $name = ‘user’;
public function userList()
{
$db_config = \think\facade\Config::get(‘database’);
$conn = new \mysqli($db_config[‘hostname’], $db_config[‘username’], $db_config[‘password’], $db_config[‘database’], $db_config[‘hostport’]);
if($conn->connect_error) {
die(“连接失败”.$conn->connect_error);
}
$sql = ‘SELECT id, user_name FROM think_user’;
$result = $conn->query($sql);
$rows = array();
while($row = $result->fetch_assoc()) {
$rows[] = $row;
}
return $rows;
}
}
通过以上例子我们可以发现,无论是PDO方式还是mysqli方式,都需要在模型中引入配置文件并设置相关参数,然后根据不同的方式来连接数据库。
三、 数据库操作
连接成功后,我们可以进行数据库操作。在TP框架下使用数据库操作可以采用SQL语句和ORM两种方式。
1. SQL语句方式
SQL操作语句比较灵活,可以根据自己的需求灵活组合,例如:
namespace app\index\model;
use think\Model;
class UserModel extends Model
{
protected $name = ‘user’;
public function userList()
{
$db_config = \think\facade\Config::get(‘database’);
$conn = new \mysqli($db_config[‘hostname’], $db_config[‘username’], $db_config[‘password’], $db_config[‘database’], $db_config[‘hostport’]);
if($conn->connect_error) {
die(“连接失败”.$conn->connect_error);
}
$sql = “SELECT id, user_name FROM think_user WHERE age > ?”;
$stmt = $conn->prepare($sql);
$stmt->bind_param(“i”, $age);
$age = 18;
$stmt->execute();
$result = $stmt->get_result();
$rows = array();
while($row = $result->fetch_assoc()) {
$rows[] = $row;
}
return $rows;
}
}
2. ORM方式
ORM是对象关系映射,通过创建模型类的方式来操作数据库,实现对数据库的增删改查。TP框架中提供了数据库操作的API,我们只需要通过模型类来调用即可:
namespace app\index\model;
use think\Model;
class UserModel extends Model
{
protected $name = ‘user’;
public function userList()
{
return $this->where(‘age’, ‘>’, ’18’)->select();
}
}
以上代码通过模型类的方式来查询用户列表,只需调用TP框架提供的where和select方法即可。
四、
通过本文的介绍,我们可以了解到,在TP框架下,连接数据库的步骤非常简单,只需要配置数据库驱动和参数,使用PDO或mysqli方式连接数据库即可。连接成功后,我们可以使用SQL语句或ORM方式操作数据库,具体会根据实际需求而定。在实际项目开发过程中,可以根据不同的需求选择不同的方式来操作数据库,达到更好的开发效率和灵活性。