PHP与ThinkPHP连接数据库示例

news/2025/1/12 12:48:07/

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客

《2025新书 ThinkPHP 8高效构建Web应用 编程与应用开发丛书 夏磊 清华大学出版社教材书籍 9787302678236 ThinkPHP 8高效构建Web应用》【摘要 书评 试读】- 京东图书

使用VS Code开发ThinkPHP项目-CSDN博客

编程与应用开发_夏天又到了的博客-CSDN博客

7.1  PHP连接数据库

PHP支持的数据库类型非常广泛,包括MySQL、Oracle、SQL Server、MongoDB、Redis、PostgreSQL、SQLite等。以连接MySQL数据库为例,通常使用mysqli扩展或PDO(PHP Data Objects)扩展,这两个扩展需要在PHP安装目录下的php.ini中进行配置。首先打开php.ini,找到“;extension=php_mysqli”和“;extension=pdo_mysql”语句,去掉这两条语句前的分号“;”,再保存一下php.ini文件,重新启动开发服务器即可启用mysqli和PDO。

下面是PHP通过mysqli扩展连接数据库的示例,需要读者事先安装好MySQL 8数据库

//public/testmysqli.php
<?php
//连接数据库,world是MySQL自带的示例数据库,在安装MySQL时需要选择安装
$db=mysqli_connect('localhost','root','1111','world') or die("无法连接服务器"); 
print("成功连接服务器<br>");$sq = "select * from city limit 10";
$result = mysqli_query($db,$sq);while($row = mysqli_fetch_row($result)){print($row[1]."<br>");
}
mysqli_close($db);

运行服务器,在浏览器中访问http://localhost:8000/testmysqli.php,看到正确的输出结果,即表示mysqli扩展正常工作。再来看一个PHP通过PDO扩展连接数据库的示例:

//public/testpdo.php
<?php
try {//连接数据库,world是MySQL自带的示例数据库,在安装MySQL时需要选择安装$dbconnect = new PDO('mysql:host=localhost;dbname=world','root','1111');
} catch (PDOException $exception) {echo "Connection error message: " . $exception->getMessage();
}
$sqlquery = "select * from city limit 10";
$result = $dbconnect->query($sqlquery);
foreach ($result as $row){$name = $row['Name'];$countrycode = $row['CountryCode'];echo "City: $name  . $CountryCode. <br/>";
}

运行服务器,在浏览器中访问http://localhost:8000/testpdo.php,看到正确的输出结果,即表示PDO扩展已经正常工作了。

7.2  ThinkPHP连接数据库

ThinkPHP 8的数据库连接的配置跟之前的版本区别不大,在config/database.php中配置好连接信息,然后就可以编写控制器并执行查询了。

ThinkPHP 8支持多个数据库连接,默认情况下会使用默认的数据库进行连接,我们也可以通过代码指定想要采用的连接方式,这个功能使用起来非常灵活。

7.2.1  单个数据库连接

下面是一个连接数据库的配置示例:

// config/database.php
'default' => env('DB_DRIVER', 'mysql'),
// 数据库连接配置信息
'connections' => ['mysql' => [ // 连接标识符// 数据库类型'type' => env('DB_TYPE', 'mysql'),// 服务器地址'hostname' => env('DB_HOST', '127.0.0.1'),// 数据库名'database' => env('DB_NAME', 'test'),// 用户名'username' => env('DB_USER', 'root'),// 密码'password' => env('DB_PASS', '111111'),// 端口'hostport' => env('DB_PORT', '3306'),// 数据库连接参数'params' => [],// 数据库编码默认采用utf8'charset' => env('DB_CHARSET', 'utf8'),// 数据库表前缀'prefix' => env('DB_PREFIX', ''),],// 更多的数据库配置信息
]

下面列举一个在控制器中查询数据库版本的示例。

【示例7-1】

新建app/controller/Index.php文件,代码如下:

<?php
// 控制器
namespace app\controller;use think\facade\Db;class Index
{// 获取数据库版本号public function index(){print_r(Db::query('SELECT VERSION()'));}
}

运行服务器,在浏览器中访问http://localhost:8000,输出结果如下,笔者的数据库版本是8.3.0,读者的输出有可能与此结果信息不一致,这个是正常的。

Array ( [0] => Array ( [VERSION()] => 8.3.0 ) )


http://www.ppmy.cn/news/1562505.html

相关文章

Linux下实时监测双网卡的默认网卡并重新设置默认网卡

在项目使用过程中&#xff0c;碰到了一些双网卡电脑&#xff0c;连接的两个交换机中某一交换机重启。导致通信不正常的情况。 发现是默认网卡发生变化&#xff0c;当然&#xff0c;也有可能是网络连接状态变化 首先通过命令来查看默认网卡是否发生变化 route -n然后通过写入…

Network Compression(李宏毅)机器学习 2023 Spring HW13 (Boss Baseline)

1. Introduction to Network Compression 深度学习中的网络压缩是指在保持神经网络性能的同时,减少其规模的过程。这非常重要,因为深度学习模型,尤其是用于自然语言处理或计算机视觉的大型模型,训练和部署的计算成本可能非常高。网络压缩通过降低内存占用并加快推理速度,…

el-table 合并单元格

参考文章&#xff1a;vue3.0 el-table 动态合并单元格 - flyComeOn - 博客园 <el-table :data"tableData" border empty-text"暂无数据" :header-cell-style"{ background: #f5f7fa }" class"parent-table" :span-method"obj…

pytest+allure 入门

使用allure如何生成自动化测试报​​​​​​告 &#xff1f;一文详解allure的使用 。_allure测试报告-CSDN博客 例子&#xff1a; import allure import pytest import osallure.epic("闹钟") allure.feature("闹钟增删") class TestSchedule():def setu…

一键部署Netdata系统无需公网IP轻松实现本地服务器的可视化监控

文章目录 前言1.关于Netdata2.本地部署Netdata3.使用Netdata4.cpolar内网穿透工具安装5.创建远程连接公网地址6.固定Netdata公网地址 &#x1f4a1; 推荐 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。…

Elasticsearch学习(2) :DSL和RestClient实现搜索文档

之前的学习中——Elasticsearch学习(1) &#xff0c;我们已经导入了大量数据到elasticsearch中&#xff0c;实现了elasticsearch的数据存储功能。但elasticsearch最擅长的还是搜索和数据分析。 所以这篇我们研究下elasticsearch的数据搜索功能。我们分别使用DSL(Domain Specif…

Android14上使用libgpiod[gpioinfo gpioget gpioset ...]

环境 $ cat /etc/os-release NAME="Ubuntu" VERSION="20.04.5 LTS (Focal Fossa)" ID=ubuntu ID_LIKE=debian PRETTY_NAME="Ubuntu 20.04.5 LTS" VERSION_ID="20.04" HOME_URL="https://www.ubuntu.com/" SUPPORT_URL="…

计算机视觉算法实战——实例分割

✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ ​​​​​​ ​​​​​​​​​​​​ ​​​​​ 1. 算法基本原理✨✨ 实例分割&#xff08;Instance Segmentation&#xff09;是计算机视…