PHP连接达梦数据库

PDO是一种在PHP中连接数据库的接口,可以通过PDO接口使用PHP连接达梦数据库。

1、安装PHP环境

检查当前环境是否安装PHP
[root@localhost ~]# php -v
 

image.png


当前环境并未安装PHP,需要进行安装,选择安装PHP7.3版本。

2、安装 epel-release源和源管理工具yum-utils

[root@localhost ~]# yum -y install epel-release yum-utils
安装如下源
 

image.png


 

image.png


完成安装...

3、安装Remi软件源

当前操作系统为centos 7,可以执行如下语句进行安装:
[root@localhost ~]# yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpm
 

image.png


完成安装...

4、安装PHP7.3的其他依赖包

[root@localhost ~]# yum install -y php73-php-fpm php73-php-cli php73-php-bcmath php73-php-gd php73-php-json php73-php-mbstring php73-php-mcrypt php73-php-mysqlnd php73-php-opcache php73-php-pdo php73-php-pecl-crypto php73-php-pecl-mcrypt php73-php-pecl-geoip php73-php-recode php73-php-snmp php73-php-soap php73-php-xml

5、查看PHP73版本

image.png

6、启动服务,开机自启,查看状态

[root@localhost ~]# systemctl enable php73-php-fpm
[root@localhost ~]# systemctl status php73-php-fpm
[root@localhost ~]# systemctl start php73-php-fpm
如下:

image.png

7、给PHP添加达梦的驱动

达梦的php驱动路径在$DM_HOME/driver/php_pdo下(此处达梦数据库安装目录为/home/dmdba/DM_soft/DM_db)

image.png

PHP的驱动路径如下,将达梦的php驱动拷贝到该目录下:

image.png

拷贝驱动文件:

image.png

查看PHP驱动目录:

image.png

8、找到php.ini和pdo.ini配置文件

image.png

如果没有php.ini文件,可以使用该命令生成:
[root@localhost ~]# php73 -r "phpinfo();" | grep 'php.ini'

9、修改配置文件

[root@localhost ~]# vi /etc/opt/remi/php73/php.ini

image.png


在最后一行添加extension=libphp73_dm.so

[root@localhost ~]# vi /etc/opt/remi/php73/php.d/20-pdo.ini
 

image.png


在最后一行添加extension=php73_pdo_dm.so

[root@localhost ~]# vi /etc/profile
编辑系统配置文件,在最后一行添加
 

image.png


[root@localhost ~]# source /etc/profile
使改动生效

image.png


如上图所示,达梦驱动加载正常

10、PHP连接达梦数据库测试

[root@localhost workspace]# cat test.php

<?php
try{
if($pdo =new PDO("dm:host=192.168.18.6","SYSDBA","SYSDBA"))
echo "connec tsuccess!";
}
catch(PDOException $e){
print "Error: ". $e->getMessage()."<br/>";
   die();
}
?>

复制

运行PHP文件,查看执行结果
[root@localhost workspace]# php73 test.php
connec tsuccess!

使用php查询数据:

<?php
try{
if($pdo =new PDO("dm:host=192.168.18.6","SYSDBA","SYSDBA"))
echo "connec tsuccess!";
//show value
$sql="select * from test";
$stmt=$pdo->query($sql);
var_dump($stmt->fetchAll(2));
}
catch(PDOException $e){
print "Error: ". $e->getMessage()."<br/>";
   die();
}
?>

复制

执行结果如下:

image.png

输入参数查询数据:

<?php
try{
if($pdo =new PDO("dm:host=192.168.18.6","SYSDBA","SYSDBA"))
echo "connec tsuccess!\n";
//show value
$name="aaa";
$id=1;
$sql="select * from test where name=:name and id=:id";
$stmt=$pdo->prepare($sql);
$stmt->execute(array('name'=>$name,'id'=>$id));
var_dump($stmt->fetchAll(2));
}
catch(PDOException $e){
print "Error: ". $e->getMessage()."<br/>";
   die();
}
?>

复制

执行结果如下:

image.png

查询并插入数据样例:

<?php
try{
$pdo =new PDO("dm:host=192.168.18.6","SYSDBA","SYSDBA");
if(!($pdo->connect_error)){
echo "connect success!\n";
}
//show value
$name="aaa";
$id=1;
$sql="select * from test where name=:name and id=:id";
$stmt=$pdo->prepare($sql);
$stmt->execute(array('name'=>$name,'id'=>$id));
var_dump($stmt->fetchAll(2));
//insert
$sql2="insert into test values('3','ccc')";
if($pdo->query($sql2)){
  echo "insert success! \n";
}else{
  echo "insert wrong" . $pdo->error;
}
//close session
$pdo=null;
$stmt=null;
}
catch(PDOException $e){
print "Error: ". $e->getMessage()."<br/>";
   die();
}
?>

复制

修改和删除数据样例:

<?php
try{
$pdo =new PDO("dm:host=192.168.18.6","SYSDBA","SYSDBA");
if(!($pdo->connect_error)){
echo "connect success!\n";
}
//update
$name="aaa";
$id=1;
$sql="update test set name='user1' where name=:name and id=:id";
$stmt=$pdo->prepare($sql);
$stmt->execute(array('name'=>$name,'id'=>$id));
//delete
$sql2="delete from test where id=3";
if($pdo->query($sql2)){
  echo "delete success! \n";
}else{
  echo "delete wrong" . $pdo->error;
}
//close session
$pdo=null;
$stmt=null;
}
catch(PDOException $e){
print "Error: ". $e->getMessage()."<br/>";
   die();
}
?>

复制

可以使用$pdo->query和$pdo->prepare两种方式来执行SQL,这两种函数执行的逻辑与jdbc中的executeQuery和preparedstatment相同

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/477721.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

工程信号的去噪和(分类、回归和时序)预测

&#x1f680;【信号去噪及预测论文代码指导】&#x1f680; 还为小论文没有思路烦恼么&#xff1f;本人专注于最前沿的信号处理与预测技术——基于信号模态分解的去噪算法和深度学习的信号&#xff08;回归、时序和分类&#xff09;预测算法&#xff0c;致力于为您提供最精确、…

【Python爬虫】网络爬虫:信息获取与合规应用

这里写目录标题 前言网络爬虫的工作原理网络爬虫的应用领域网络爬虫的技术挑战网络爬虫的伦理问题结语福利 前言 网络爬虫&#xff0c;又称网络爬虫、网络蜘蛛、网络机器人等&#xff0c;是一种按照一定的规则自动地获取万维网信息的程序或者脚本。它可以根据一定的策略自动地浏…

常用的6个的ChatGPT网站,国内可用!

GPTGod &#x1f310; 链接&#xff1a; GPTGod &#x1f3f7;️ 标签&#xff1a; GPT-4 免费体验 支持API 支持绘图 付费选项 &#x1f4dd; 简介&#xff1a;GPTGod 是一个功能全面的平台&#xff0c;提供GPT-4的强大功能&#xff0c;包括API接入和绘图支持。用户可以选择免…

【阿里魔搭】modelscope包下载安装

最终解决方案&#xff1a;使用源码安装modelscope 这里写目录标题 问题描述&#xff1a;pip安装包冲突安装步骤 问题描述&#xff1a;pip安装包冲突 一开始的是在3.11的虚拟环境下使用命令行pip install "modelscope[nlp]" -f https://modelscope.oss-cn-beijing.al…

DUSt3R:简化三维重建

3D 重建是从二维 (2D) 图像创建对象或场景的 3D 虚拟表示的任务&#xff0c;可用于模拟、可视化或本地化等多种目的。 它广泛应用于计算机视觉、机器人和虚拟现实&#xff08;VR&#xff09;等多个领域。 在基本设置中&#xff0c;3D 重建方法输入一对图像 I1 和 I2&#xff0c…

字体测试集:选取、应用与兼容性指南

1. 字体测试集 本人非专业字体工作者&#xff0c;字体测试集为个人经验总结整理&#xff0c;仅供参考 那时&#xff0c;天下人的口音、言语都是一样。 南去經三國&#xff0c;東來過五湖 南去经三国&#xff0c;东来过五湖 永东国酬爱郁灵鹰袋 0Oo1lI ga The quick brown fox j…

6个免费的ChatGPT网站

AI 大模型的出现给时代带来了深远的影响&#xff1a; 改变了产业格局&#xff1a;AI 大模型的发展推动了人工智能技术在各行业的广泛应用&#xff0c;改变了传统产业的运作方式&#xff0c;促进了新兴产业的崛起&#xff0c;如智能驾驶、医疗健康、金融科技等。提升了科学研究…

微软发布首款AI PC ,产业链有望迎来新一轮量价齐升

3月21日晚&#xff0c;微软举办主题为“办公新时代”的线上新品发布会&#xff0c;发布Surface Pro 10和Surface Laptop 6&#xff0c;新品将搭载基于英特尔酷睿Ultra或高通骁龙X Elite的处理器&#xff0c;配备新一代NPU&#xff0c;以增强AI性能。 这两款AI PC将支持“AI Exp…

土地利用的时序建模

1、LULC 模型的现状 最近的土地利用和土地覆盖 (LULC) 建模进展来自两种方法。 在一种方法中&#xff0c;现有模型适用于 LULC&#xff0c;而在另一种方法中&#xff0c;模型架构是针对 LULC 明确设计的。 随着大型基础模型的兴起&#xff0c;人工智能和深度学习取得了重大进…

数据结构 二叉树 力扣例题AC——代码以及思路记录

LCR 175. 计算二叉树的深 某公司架构以二叉树形式记录&#xff0c;请返回该公司的层级数。 AC int calculateDepth(struct TreeNode* root) {if (root NULL){return 0;}else{return 1 fmax(calculateDepth(root->left), calculateDepth(root->right));} } 代码思路 …

【Linux C | 多线程编程】线程的创建、线程ID、线程属性

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; ⏰发布时间⏰&#xff1a;2024-03-22 0…

SSC9211_USB-CAM解决方案

一、方案描述 SSC9211是一种用于USB-CAM应用程序跟场景的高度集成的SOC产品。平台本身基于ARM层-A7双核&#xff0c;内置16位&#xff0c;64M的DDR2&#xff0c;集成了图像传感器接口、高级ISP、高性能JPEG编码器和其他丰富的外设接口。支持单&#xff0c;双 MIPI sensor方案&…

H3C--堆叠(IRF)

拓扑图 配置流程 配置SW1与SW2堆叠 一、SW1&#xff1a; shutdown 物理端口配置堆叠优先级&#xff0c;优先级高的成为主设备创建堆叠逻辑接口&#xff0c;将物理接口加入到堆叠逻辑接口中 二、SW1&#xff1a; sysname SW1 # irf member 1 priority 6 # irf-port 1/1port…

基于时空上下文(STC)的运动目标跟踪算法,Matlab实现

博主简介&#xff1a; 专注、专一于Matlab图像处理学习、交流&#xff0c;matlab图像代码代做/项目合作可以联系&#xff08;QQ:3249726188&#xff09; 个人主页&#xff1a;Matlab_ImagePro-CSDN博客 原则&#xff1a;代码均由本人编写完成&#xff0c;非中介&#xff0c;提供…

windowsVMware虚拟机中扩展linux磁盘空间

1.虚拟磁盘扩容 VM中&#xff0c;关闭linux虚拟机&#xff0c;直接编辑虚拟机-硬盘-扩展磁盘容量 2.通过Gparted工具进行LINUX系统磁盘分区 未分区挂载前可以看到/挂载点下空间为20G&#xff1a; 通过虚拟机-快照-拍摄快照&#xff0c;操作前可拍摄快照&#xff08;便于恢复之前…

科技云报道:造完“大模型”,“具身智能”将引领AI下一个浪潮?

科技云报道原创。 资深机器人专家Eric Jang不久前曾预言&#xff1a;“ChatGPT 曾在一夜之间出现。我认为&#xff0c;有智慧的机器人技术也将如此。” 3月13日深夜&#xff0c;一段人形机器人的视频开始热传。 在视频中&#xff0c;Figure的人形机器人&#xff0c;可以完全…

基于java+springboot+vue实现的健身房管理系统(文末源码+Lw+ppt)23-523

摘 要 健身房管理的以往工作流程繁杂、多样、管理复杂与设备维护繁琐。而如今计算机已完全能够胜任健身房管理工作&#xff0c;而且更加准确、方便、快捷、高效、清晰、透明&#xff0c;它完全可以克服以上所述的不足之处。这将给查询信息和管理带来很大的方便&#xff0c;从…

从0写一个问卷调查APP的第13天-1

1.今日任务 我也只是一个大学生&#xff0c;有什么思路不对的地方给我指出来哟! 分析&#xff1a;上次我们实现了任务调查的插入。但是我们插入的问卷调查只有它的标题&#xff0c;也就是这个问卷调查是什么我们告诉数据库了&#xff0c;但是现在我们还没有给它添加任何问题&…

图片如何去除水印?试试这三款去水印工具!

在处理图片时&#xff0c;经常会遇到一个棘手的问题&#xff1a;水印。不论是想去除不美观的版权标记&#xff0c;还是希望消除图片上的杂物&#xff0c;一个好用的去水印工具都是必不可少的。今天&#xff0c;我们就为大家介绍三款功能强大、操作简便的图片去水印软件&#xf…

JavaScrpt学习笔记_一

一、Js编写位置 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> <!-- 可以将js代码编写到外部js文件中&#xff0c;然后通过script标签引入写到外部文件中可以在不同页面中…