0

0

PHP的主流架构都支持哪些数据库_兼容列表【介绍】

絕刀狂花

絕刀狂花

发布时间:2025-12-30 16:22:02

|

381人浏览过

|

来源于php中文网

原创

PHP主流框架通过PDO支持MySQL、PostgreSQL、SQLite、SQL Server、Oracle等关系型数据库,但Eloquent仅原生完整支持mysql、pgsql、sqlite、sqlsrv;NoSQL需独立扩展,不参与ORM流程。

php的主流架构都支持哪些数据库_兼容列表【介绍】

PHP 本身不是“架构”,而是语言;所谓“主流架构”通常指 Laravel、Symfony、ThinkPHP 等框架,或 LAMP/LEMP 这类部署栈。它们对数据库的支持,本质上取决于底层 PHP 扩展 + PDO 抽象层 + ORM 实现。结论很明确:只要 PHP 能连,主流框架基本都支持——但支持深度和默认开箱体验差异很大。


哪些数据库能直接用 PDO 一键切换?

PDO 是 PHP 官方提供的统一数据库访问接口,它不处理具体逻辑,只提供标准化调用方式。只要安装对应驱动,改个 DSN 字符串就能换库,代码几乎不用动。

  • PDO_MYSQL:MySQL / MariaDB(最稳,文档最全,Laravel 默认)
  • PDO_PGSQL:PostgreSQL(支持 JSONB、数组、事务隔离级别,但部分 ORM 对 pg 的 RETURNING 语法适配不全)
  • PDO_SQLITE:SQLite(单文件、无服务,适合 CLI 工具或测试,但不支持并发写入)
  • PDO_SQLSRV:Microsoft SQL Server(Windows 下原生好用,Linux 需装 msodbcsqlunixODBC,连接字符串格式和 MySQL 差很多)
  • PDO_ORACLE:Oracle(需 Oracle Instant Client,扩展名是 oci8,不是 PDO_OCI;Laravel 官方不维护,社区包如 yajra/laravel-oci8 维护较吃力)

⚠️ 注意:PDO_DBLIB(用于 SQL Server 的旧 FreeTDS 方案)已弃用,PHP 8.2+ 不再推荐;PDO_FIREBIRDPDO_INFORMIX 等存在但极少有人用,文档和生态基本停滞。


Laravel/Eloquent 默认兼容哪些?

Laravel 的 Eloquent 是 ActiveRecord 模式 ORM,它的“支持列表”不等于“能连”,而是“能自动映射、迁移、软删除、关系加载”的数据库。实际支持范围比 PDO 更窄:

立即学习PHP免费学习笔记(深入)”;

  • ✅ 原生完整支持:mysqlpgsqlsqlitesqlsrv
  • ⚠️ 有限支持:mariadb(走 mysql 驱动,但部分新特性如 JSON_CONTAINS 需手动写 raw 查询)
  • ❌ 不支持:redismongodbelasticsearch —— 它们不是关系型数据库,Eloquent 不处理这类数据模型

比如你配 DB_CONNECTION=pgsql,Laravel 迁移命令 php artisan migrate 就能建表、加索引、设主键;但换成 Redis,这个命令根本不会识别你的 redis 配置,因为 Eloquent 不把它当“数据库表”看待。

Solvely
Solvely

AI学习伴侣,数学解体,作业助手,家教辅导

下载

非关系型数据库怎么接入 PHP 主流项目?

Redis、MongoDB、Elasticsearch 这类 NoSQL 数据库,在 PHP 中不是靠 PDO,而是靠独立扩展 + 客户端库。它们通常不参与 ORM 流程,而是作为辅助存储单独使用:

  • redis:用 phpredis(C 扩展)或 predis(纯 PHP 库)。Laravel 用 cachesession 驱动对接,但不能用 Model::find() 查 Redis
  • mongodb:官方 mongodb/mongodb Composer 包 + ext-mongodb 扩展。Laravel 没有内置 Model 支持,得用第三方包如 jenssegers/mongodb(注意:该包已停止维护,PHP 8.2+ 兼容性差)
  • elasticsearch:用 elasticsearch/elasticsearch 官方客户端,走 HTTP API,和 DB 层完全解耦;搜索逻辑写在 Service 层,不进 Migration 或 Model

常见错误:试图用 Eloquent 直接操作 MongoDB 文档,结果报 Call to undefined method Illuminate\Database\Query\Builder::whereRaw() —— 因为底层驱动根本不认识这个方法。


为什么有些数据库“能连却不好用”?

能建立连接 ≠ 能流畅开发。真正卡住人的,往往是细节兼容性断层:

  • MySQL 的 ONLY_FULL_GROUP_BY 模式开启后,Laravel 的某些聚合查询会直接报错,而 PostgreSQL 默认就严格遵循标准,反而更早暴露问题
  • SQLite 不支持 ALTER TABLE ... DROP COLUMN,所以 php artisan migrate:fresh 在 SQLite 上可能失败,得手动删库重来
  • SQL Server 的标识列(IDENTITY)和 Laravel 的自增主键约定冲突,insertGetId() 可能返回 0,必须显式指定 DB::connection()->getPdo()->lastInsertId()
  • Oracle 的表名/字段名默认大写,而 Laravel 的 Schema Builder 生成的 SQL 是小写,不加双引号就会报 ORA-00942: table or view does not exist

这些不是“不支持”,而是“支持但要绕路”。上线前务必在目标数据库上跑完全部 migration + seed + feature test,别只在本地 SQLite 里验证通过就合代码。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1916

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1255

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1162

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1399

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1229

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

桌面文件位置介绍
桌面文件位置介绍

本专题整合了桌面文件相关教程,阅读专题下面的文章了解更多内容。

0

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 776人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号