当前位置: 首页 > news >正文

PHP环境安装达梦数据库驱动实操

PHP环境安装达梦数据库驱动实操


一、环境准备

  1. 达梦数据库安装

    • 从达梦官网下载对应系统版本的DM8开发版或企业版,完成安装并确保数据库服务正常运行。
    • 安装后需记录数据库的安装路径(如Windows默认路径为D:\dmdbms,Linux为/dm/server),后续配置会用到。
  2. PHP环境要求

    • PHP版本需与达梦驱动兼容(推荐7.2+,需确认线程安全类型:TS或NTS)。
    • 通过phpinfo()查看PHP扩展目录(extension_dir)及线程安全状态(Thread Safety)。

二、Windows系统安装步骤

1. 获取达梦PHP驱动文件

  • 在达梦安装目录的drivers/php_pdo子目录下找到对应PHP版本的驱动文件(如php73_dm.dllpdo73_dm.dll),注意区分线程安全(TS)与非线程安全(NTS)版本。

2. 配置PHP扩展

  • 复制驱动文件:将php73_dm.dllpdo73_dm.dll复制到PHP的ext目录(如D:\php7.3\ext)。
  • 修改php.ini
    php.ini末尾添加以下内容(路径替换为实际驱动文件路径):
    extension=D:\dmdbms\drivers\php_pdo\php73_dm.dll
    extension=D:\dmdbms\drivers\php_pdo\pdo73_dm.dll
    
  • 添加依赖库:将达梦的bin目录(如D:\dmdbms\bin)添加到系统环境变量Path中,避免提示dmcalc.dll缺失。

3. 验证驱动加载

  • 重启Web服务器(如Apache/Nginx)或命令行执行php -m,检查输出中是否包含dmpdo_dm模块。
  • 若报错“Unable to start DM module”,需检查驱动文件版本与PHP是否匹配,或依赖库路径是否正确。

三、Linux系统安装步骤

1. 解决依赖冲突

  • 备份并删除冲突的so文件
    达梦的部分动态库(如libcrypto.so)可能与系统库冲突,需执行:
    cp -r /dm/server/bin /dm/server/bin3
    cd /dm/server/bin3
    rm -rf libcrypto.so libssl.so libtiff.so libxml2.so libxqilla.so
    
    删除对应的软链接。

2. 配置环境变量

  • 编辑/etc/profile,添加以下内容:
    export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/dm/server/bin3"
    export DM_HOME="/dm/server"
    export PATH="$PATH:$DM_HOME/bin:$DM_HOME/tool"
    
  • 执行source /etc/profile使配置生效。

3. 加载驱动到系统库

  • 创建配置文件/etc/ld.so.conf.d/dameng.conf,写入达梦库路径:
    /dm/server/bin3
    
  • 执行ldconfig更新库缓存。

4. 配置PHP扩展

  • php.ini中添加:
    [PHP_DM]
    extension=/dm/server/drivers/php_pdo/libphp72_dm.so
    extension=/dm/server/drivers/php_pdo/php72_pdo_dm.so
    
  • 重启PHP-FPM或Web服务,通过php -m验证驱动加载。

四、连接达梦数据库示例代码

1. 使用PDO方式连接

<?php
$dsn = "dm:host=127.0.0.1;port=5236;dbname=DAMENG";
$user = "SYSDBA";
$password = "SYSDBA";try {$pdo = new PDO($dsn, $user, $password);echo "连接达梦数据库成功!";// 执行查询示例$stmt = $pdo->query("SELECT * FROM SYSOBJECTS");while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {print_r($row);}
} catch (PDOException $e) {die("连接失败: " . $e->getMessage());
}
?>

2. 使用达梦原生函数连接

<?php
$conn = dm_connect("127.0.0.1:5236", "SYSDBA", "SYSDBA");
if ($conn) {echo "连接成功!";dm_exec($conn, "CREATE TABLE test (id INT, name VARCHAR(20))");dm_close($conn);
} else {echo "连接失败!";
}
?>

五、常见问题排查

  1. 驱动未加载

    • 检查php.ini中扩展路径是否正确,确保文件权限可读。
    • 确认PHP版本与驱动版本匹配,线程安全类型一致。
  2. 依赖库缺失

    • Windows需将达梦bin目录加入Path;Linux需通过ldconfig更新库路径。
  3. 连接超时或拒绝

    • 检查达梦服务是否启动,防火墙是否开放端口(默认5236)。

六、参考文档

  • 达梦官方PHP驱动文档:https://eco.dameng.com/document/dm/zh-cn/faq/faq-php.html
  • Windows环境详细配置:CSDN博客:PHP7.3加载达梦驱动
  • Linux冲突库处理:CSDN博客:PHP加载达梦驱动

通过以上步骤,可确保PHP与达梦数据库的驱动正确安装及连接。建议在操作前备份系统配置,并根据实际环境调整路径参数。

相关文章:

PHP环境安装达梦数据库驱动实操

PHP环境安装达梦数据库驱动实操 一、环境准备 达梦数据库安装 从达梦官网下载对应系统版本的DM8开发版或企业版&#xff0c;完成安装并确保数据库服务正常运行。安装后需记录数据库的安装路径&#xff08;如Windows默认路径为D:\dmdbms&#xff0c;Linux为/dm/server&#xff0…...

Electron + Vite + React + TypeScript 跨平台开发实践指南

Electron Vite React TypeScript 跨平台开发全栈实践指南 开发环境的搭建(node.js&#xff0c;npm的安装)请参见我的文章 2025Q1 核心组件版本矩阵 组件版本关键改进特性Electron30.0.0原生ESM支持、V8引擎性能优化30%Vite6.0.0多核编译加速、SSR增强模式React21.0.0并发…...

Java---入门基础篇(下)---方法与数组

前言 本篇文章主要讲解有关方法与数组的知识点 ,是基础篇的一部分 , 而在下一篇文章我会讲解类和对象的知识点 入门基础篇上的链接给大家放在下面啦 ! Java---入门基础篇(上)-CSDN博客 感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb; 欢迎各位大佬指点…...

【分布式理论11】分布式协同之分布式事务(一个应用操作多个资源):从刚性事务到柔性事务的演进

文章目录 一. 什么是分布式事务&#xff1f;二. 分布式事务的挑战三. 事务的ACID特性四. CAP理论与BASE理论1. CAP理论1.1. 三大特性1.2. 三者不能兼得 2. BASE理论 五. 分布式事务解决方案1. 两阶段提交&#xff08;2PC&#xff09;2. TCC&#xff08;Try-Confirm-Cancel&…...

【文献阅读】Collective Decision for Open Set Recognition

基本信息 文献名称&#xff1a;Collective Decision for Open Set Recognition 出版期刊&#xff1a;IEEE TRANSACTIONS ON KNOWLEDGE AND DATA ENGINEERING 发表日期&#xff1a;04 March 2020 作者&#xff1a;Chuanxing Geng and Songcan Chen 摘要 在开集识别&#xff0…...

Gorm中的First()、Create()、Update()、Delete()的错误处理

一. First() result : tx.Model(&models.Attachment{}).Where("home ? AND home_id ?", attachment.Home, attachment.HomeID).First(&existingAttachment)如果没有查询到数据&#xff0c;result.Error的值是什么&#xff1f; 在使用 GORM&#xff08;…...

【心得】一文梳理高频面试题 HTTP 1.0/HTTP 1.1/HTTP 2.0/HTTP 3.0的区别并附加记忆方法

面试时很容易遇到的一个问题—— HTTP 1.0/HTTP 1.1/HTTP 2.0/HTTP 3.0的区别&#xff0c;其实这四个版本的发展实际上是一环扣一环的&#xff0c;是逐步完善的&#xff0c;本文希望帮助读者梳理清楚各个版本之间的区别&#xff0c;并且给出当前各个版本的应用情况&#xff0c;…...

Navicat连接虚拟机数据库详细教程

Navicat连接虚拟机数据库详细教程 以Windows主机 上的navicat 连接ubuntu虚拟机为例 确认虚拟机ip地址和主机ip地址 主机地址查询 cmd输入ipconfig 登录mysql 创建用户 CREATE USER newuserlocalhost IDENTIFIED BY password; CREATE USER newuser% IDENTIFIED BY passwor…...

委托者模式(掌握设计模式的核心之一)

目录 问题&#xff1a; 举例&#xff1a; 总结&#xff1a;核心就是利用Java中的多态来完成注入。 问题&#xff1a; 今天刷面经&#xff0c;刷到装饰者模式&#xff0c;又进阶的发现委托者模式&#xff0c;发现还是不理解&#xff0c;特此记录。 举例&#xff1a; ​老板​…...

DeepSeek-R1 论文笔记:通过强化学习提升大语言模型的推理能力

论文标题&#xff1a;DeepSeek-R1: Incentivizing Reasoning Capability in LLMs via Reinforcement Learning 作者团队&#xff1a;DeepSeek-AI 发表时间&#xff1a;2025 前置知识 & 术语 模型蒸馏 语言模型蒸馏的目标是将大型教师模型的知识&#xff08;如语义理解、上…...

实现Unity shader扭曲效果

实现思路 1、扭曲材质赋于面片 2、抓取当前一帧的图片内容 3、获取屏幕坐标 4、利用屏幕坐标对抓取的图片采样 5、再采样张扰动贴图做扭曲 Shader "Unlit/NewUnlitShader" {Properties {_DistortTex ("扰动贴图 (RGB)", 2D) "bump" {}_Di…...

七星棋牌 6 端 200 子游戏全开源修复版源码(乐豆 + 防沉迷 + 比赛场 + 控制)

七星棋牌源码 是一款运营级的棋牌产品&#xff0c;覆盖 湖南、湖北、山西、江苏、贵州 等 6 大省区&#xff0c;支持 安卓、iOS 双端&#xff0c;并且 全开源。这个版本是 修复优化后的二开版本&#xff0c;新增了 乐豆系统、比赛场模式、防沉迷机制、AI 智能控制 等功能&#…...

C++STL---<limits>

C <limits> 头文件&#xff1a; <limits> 头文件是 C 标准库中用于获取各种数据类型的数值范围、精度等信息的工具。它通过模板类 std::numeric_limits 提供了对基本数据类型&#xff08;如 int、float、double 等&#xff09;的详细属性查询功能。通过 std::nume…...

一键安装Mysql部署脚本之Linux在线安装Mysql,脚本化自动化执行服务器部署(附执行脚本下载)

相关链接 一键安装Redis部署脚本之Linux在线安装Redis一键安装Mysql部署脚本之Linux在线安装Mysql一键安装JAVA部署脚本之Linux在线安装JDK一键安装Nginx部署脚本之Linux在线安装NginxNavicat最新版(17)详细安装教程Xshell客户端免费版无需注册XFtp客户端免费版无需注册 前言…...

ES、OAS、ERP、电子政务、企业信息化(高软35)

系列文章目录 ES、OAS、ERP、电子政务、企业信息化 文章目录 系列文章目录前言一、专家系统&#xff08;ES&#xff09;二、办公自动化系统&#xff08;OAS&#xff09;三、企业资源规划&#xff08;ERP&#xff09;四、典型信息系统架构模型1.政府信息化和电子政务2.企业信息…...

文生图开源模型发展史(2014-2025年)

文生图开源模型的发展历程是一段充满技术革新、社区生态繁荣与商业化竞争的多维度演进史。 一、技术萌芽期&#xff08;2014-2020年&#xff09; 核心突破 2014年&#xff1a;GAN&#xff08;生成对抗网络&#xff09;诞生&#xff0c;首次实现数据驱动式图像生成&#xff0…...

OA办公系统自动渗透测试过程

目录 一、下载环境源码 二、部署环境 三、测试 XSS漏洞 SQL注入 文件上传漏洞 一、下载环境源码 OA源码打包地址: https://download.csdn.net/download/weixin_43650289/90434502?spm=1001.2014.3001.5503 二、部署环境...

Python标准库【os】5 文件和目录操作2

文章目录 8 文件和目录操作8.7 浏览目录下的内容8.8 查看文件或目录的信息8.9 文件状态修改文件标志位文件权限文件所属用户和组其它 8.10 浏览Windows的驱动器、卷、挂载点8.11 系统配置信息 os模块提供了各种操作系统接口。包括环境变量、进程管理、进程调度、文件操作等方面…...

[代码规范]接口设计规范

一个优雅的接口要如何设计&#xff1f;有哪些设计规范可以遵循&#xff1f; 下面抛砖引玉&#xff0c;分享一些规范。 目录 1、RESTful API 设计最佳实践 2、Shneiderman 的 8 条黄金法则 3、Nielsen 的 10 条启发式规则 1、RESTful API 设计最佳实践 一共18条&#xff0c;参考…...

什么是最终一致性,它对后端系统的意义是什么

最终一致性(Eventual Consistency)是分布式系统中的一种一致性模型。与传统的强一致性模型不同,最终一致性并不要求系统在任何时刻都保持一致,而是保证在足够的时间后,所有节点的数据最终会达到一致的状态。换句话说,系统允许短时间内出现数据的不一致性,但最终会通过某…...

终极TensorFlow Rust数学运算指南:从基础算术到复杂函数完全掌握

终极TensorFlow Rust数学运算指南&#xff1a;从基础算术到复杂函数完全掌握 【免费下载链接】rust Rust language bindings for TensorFlow 项目地址: https://gitcode.com/gh_mirrors/rust/rust TensorFlow Rust为开发者提供了强大的数学运算能力&#xff0c;通过Rust…...

安防弱电智能化VISIO图例实战指南:从入门到精通的设计技巧

1. VISIO在安防弱电设计中的核心价值 第一次接触安防弱电智能化设计时&#xff0c;我被各种复杂的系统连接关系搞得头晕眼花。直到发现VISIO这个神器&#xff0c;才真正体会到什么叫"一图胜千言"。不同于普通CAD软件&#xff0c;VISIO最大的优势在于它专为系统图设计…...

深度解析:利用pmap+gdb精准诊断Linux进程内存异常

1. 为什么需要pmapgdb组合排查内存问题 第一次遇到线上服务内存爆涨时&#xff0c;我盯着top命令里那个不断攀升的RES数值束手无策。传统的内存监控工具就像医院的体温计&#xff0c;只能告诉你"发烧了"&#xff0c;但查不出具体病因。这就是pmap和gdb这对"黄金…...

智能音乐情绪生成器:当AI遇见音乐,用代码谱写情感旋律

引言&#xff1a;音乐与情感的数字化探索音乐是人类情感最直接的表达方式之一&#xff0c;欢快的旋律让人振奋&#xff0c;悲伤的曲调令人沉思。在人工智能时代&#xff0c;我们能否让机器理解情感&#xff0c;并创作出符合特定情绪的音乐&#xff1f;本文将带你走进一个融合了…...

CodeSys随机数生成实战:从GPS通信验证到实验作业的完整代码解析

CodeSys随机数生成实战&#xff1a;从GPS通信验证到实验作业的完整代码解析 在工业自动化领域&#xff0c;随机数生成看似是个小众需求&#xff0c;直到你遇到需要模拟设备故障、生成验证码或创建随机测试场景时才会发现它的重要性。CodeSys作为工业控制领域的"瑞士军刀&…...

避坑指南:在Ubuntu 18.04 ROS Melodic下,从rosbag转视频到底有多少种方法?

ROS Melodic下rosbag转视频的5种实战方案与避坑指南 当你第一次尝试将ROS bag文件中的图像数据转换为视频时&#xff0c;可能会被各种工具和方法搞得晕头转向。作为一个在机器人视觉领域摸爬滚打多年的开发者&#xff0c;我经历过无数次rosbag转视频的失败尝试&#xff0c;也踩…...

高性能Python爬虫数据预处理流水线:PyTorch 2.8与Dask并行计算实战

高性能Python爬虫数据预处理流水线&#xff1a;PyTorch 2.8与Dask并行计算实战 1. 爬虫数据处理的现实挑战 每天都有海量数据从互联网上被爬取下来&#xff0c;但很少有人告诉你这些原始数据有多"脏"。我曾经接手过一个电商评论分析项目&#xff0c;原始数据里混杂…...

DETR训练避坑大全:Windows10+PyCharm环境下的5个常见报错解决方案

DETR实战指南&#xff1a;Windows 10环境下的5大典型问题深度解析与解决方案 在目标检测领域&#xff0c;DETR&#xff08;Detection Transformer&#xff09;作为首个完全基于Transformer架构的端到端检测系统&#xff0c;正在改变传统计算机视觉任务的实现方式。不同于Faste…...

Mojo加速Python科学计算:从API绑定到内存零拷贝,5步完成CUDA级性能跃迁

第一章&#xff1a;Mojo加速Python科学计算&#xff1a;从API绑定到内存零拷贝&#xff0c;5步完成CUDA级性能跃迁Mojo 作为兼具 Python 兼容性与系统级性能的新一代编程语言&#xff0c;正重塑科学计算的性能边界。其核心优势在于原生支持异构硬件&#xff08;如 NVIDIA GPU&a…...

从零部署RT-DETR:手把手教你训练自定义目标检测数据集

1. RT-DETR简介与环境配置 RT-DETR是百度推出的实时目标检测Transformer模型&#xff0c;相比传统CNN架构的YOLO系列&#xff0c;它在保持高精度的同时实现了更快的推理速度。我第一次接触这个模型时&#xff0c;就被它的"端到端检测"特性吸引了——不需要复杂的后处…...