0

0

php连Access数据库_windows环境mdb文件的访问方法【解答】

絕刀狂花

絕刀狂花

发布时间:2026-03-02 19:35:03

|

642人浏览过

|

来源于php中文网

原创

php连接access需用32位odbc驱动,连接字符串须用绝对路径和正斜杠,中文/空格字段名用方括号,日期用#yyyy-mm-dd#格式,null值须为字面量。

php连access数据库_windows环境mdb文件的访问方法【解答】

PHP 用 odbc_connect 连 Access(.mdb)必须装 32 位驱动

Windows 上 PHP 默认是 32 位(哪怕系统是 64 位),而新版 Windows 自带的 Access Database Engine 是 64 位,直接装会报错:[Microsoft][ODBC 驱动程序管理器] 未发现数据源名称并且未指定默认驱动程序

解决办法只有装 32 位驱动——去微软官网搜 AccessDatabaseEngine_X86.exe 下载安装,别选带 x64 的。装完重启 PHP 服务(比如 Apache 或 php-fpm)。

  • PHP 进程和 ODBC 驱动位数必须严格一致,不匹配就 odbc_connect 返回 false
  • 如果用 WAMP/XAMPP,确认它自带的 PHP 是 32 位(php -v 看不到 “x64” 字样基本就是)
  • 驱动装好后,在 Windows 的 ODBC 数据源(32 位) 里能看到 Microsoft Access Driver (*.mdb, *.accdb)

连接字符串里路径不能用反斜杠或相对路径

odbc_connect 的 DSN 部分对路径很敏感,写错一个字符就连接失败,常见错误是路径里混用 \/,或者用了 ./data.mdb 这类相对路径。

必须用绝对路径、正斜杠、且路径要能被 PHP 进程读取(注意 IIS/Apache 用户权限):

遨虾
遨虾

1688推出的跨境电商AI智能体

下载

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

  • 正确写法:DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=C:/web/data.mdb;
  • 错误写法:DBQ=C:\web\data.mdb(反斜杠在双引号里会被转义成换行或制表符)
  • 错误写法:DBQ=./data.mdb(PHP 不会自动补全当前脚本目录,而是按 Web 服务器工作目录解析,通常不是你想要的)
  • 如果路径含中文或空格,不用加引号,Access 驱动本身不支持引号包裹路径

查询中文字段名或含空格字段时必须用方括号

Access 允许字段名带空格、中文甚至标点,但 ODBC 层不认,直接写 SELECT 姓名 FROM users 会报错:[Microsoft][ODBC Microsoft Access Driver] 语法错误 (操作符丢失) 在查询表达式 '姓名' 中

所有非标准标识符都得用方括号包起来:

  • 中文字段:SELECT [姓名], [用户 ID] FROM [用户表]
  • 含空格字段:SELECT [First Name], [Last Name] FROM [Contacts]
  • 表名也一样,如果表名是 Order Details,就得写 FROM [Order Details]
  • 别用反引号(`)或双引号,Access 只认方括号

INSERT/UPDATE 时日期和 NULL 值容易出错

Access 对日期字面量格式极敏感,写错就静默失败或插成 1899-12-30;NULL 值如果传了空字符串或未定义变量,反而会存成空字符串而不是 NULL。

  • 插入日期必须用 #2024-05-20# 格式(井号包裹,且必须是 YYYY-MM-DD),不能用单引号或 PHP 的 date() 直接拼
  • 显式插入 NULL:写 INSERT INTO t (name, birth) VALUES ('张三', NULL),别传空字符串、'NULL' 或变量未初始化
  • 字段设为“允许 Null”,但 ODBC 默认把空值当空字符串处理,所以 PHP 侧要确保 NULL 是字面量,不是字符串
  • Access 不支持 LAST_INSERT_ID(),想取刚插入的主键得用 SELECT @@IDENTITY(需同个连接、紧接 INSERT 后执行)
Access 的 ODBC 支持很老,很多现代 PHP 特性(如 PDO 的预处理绑定)对它无效,参数只能拼字符串,字段名、值、日期格式全得手动兜底。真正上线项目现在基本没人用 mdb 了,但如果真要维护旧系统,位数、路径、括号、日期这四点漏掉任何一个都会卡住半天。

相关文章

Windows激活工具
Windows激活工具

Windows激活工具是正版认证的激活工具,永久激活,一键解决windows许可证即将过期。可激活win7系统、win8.1系统、win10系统、win11系统。下载后先看完视频激活教程,再进行操作,100%激活成功。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

249

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

967

2024.03.01

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

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

1643

2023.10.23

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

313

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

290

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

172

2025.08.07

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

678

2023.08.03

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

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

精品课程

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

共137课时 | 12.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

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

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