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相同

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

人工智能时代的引领者:AI提示工程激发大语言模型的无限潜能

文章目录 一、AI提示工程的概念与定义二、AI提示工程的应用领域三、AI提示工程的技术创新与突破四、AI提示工程的未来发展趋势《AI提示工程实战&#xff1a;从零开始利用提示工程学习应用大语言模型》亮点内容简介作者简介目录 一、AI提示工程的概念与定义 在当今日新月异的科…

分类预测 | Matlab实现BiTCN双向时间卷积神经网络数据分类预测/故障识别

分类预测 | Matlab实现BiTCN双向时间卷积神经网络数据分类预测/故障识别 目录 分类预测 | Matlab实现BiTCN双向时间卷积神经网络数据分类预测/故障识别分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现BiTCN双向时间卷积神经网络数据分类预测/故障识别。 2.自…

mysql四种事务隔离级别,2024金三银四

TransactionDefinition.PROPAGATION_MANDATORY&#xff1a;如果当前存在事务&#xff0c;则加入该事务&#xff1b;如果当前没有事务&#xff0c;则抛出异常。 TransactionDefinition.PROPAGATION_NESTED&#xff1a;如果当前存在事务&#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));} } 代码思路 …

利用matplot绘制折线图(详细版-有示例数据)

对于五组数据&#xff0c;绘制折线图&#xff0c;添加有图例、不同折线的颜色等&#xff0c;如下图所示&#xff1a; python代码&#xff1a; import matplotlib.pyplot as plt import numpy as np# 定义数据 data [[1, 2, 3, 4, 5, 6, 7, 8], # 数据1[2, 2, 4, 4, 5, 5, 6,…

【Godot 3.5组件】简单血条组件HealthBar

说明 本文原文写自2022年&#xff0c;内容基于Godot3.5。是本人早期进行Godot组件化和自定义节点探索时的产物&#xff0c;当时的代码和思想可能不太成熟&#xff0c;但贴出来&#xff0c;供需要学习组件化基础思路的同学食用。 概述 血条作为一个非常基础和常见的组件&…

C语言易错知识点:二级指针、数组指针、函数指针

指针在C语言中非常关键&#xff0c;除开一些常见的指针用法&#xff0c;还有一些可能会比较生疏&#xff0c;但有时却也必不可少&#xff0c;本文章整理了一些易错知识点&#xff0c;希望能有所帮助&#xff01; 1.二级指针&#xff1a; parr是一个指针数组&#xff0c;其中每…

国创证券|上市公司破产了手里的股票怎么办?

上市公司破产了&#xff0c;那只能等候公司破产清算补偿。 上市公司破产后&#xff0c;公司的财物将进行清算&#xff0c;还完债款假如还有剩下财物&#xff0c;就会分给持有股票的股民。一般优先偿还借主、再偿还优先股东&#xff0c;最终才是一般股东&#xff0c;假如资不抵…

【网络编程基础(三)】线程同步

学习分享 1、线程同步2、用信号量进行同步2.1、信号量函数2.2、创建一个信号量2.3、sem_post函数 &#xff08;解锁&#xff09;2.4、sem_wait函数 (加锁)2.5、sem_destroy函数2.6、信号量示例 3、用互斥量进行同步3.1、互斥量函数数组3.2、互斥量示例 1、线程同步 两个&#x…

Spring Web MVC入门(6)

应用分层 在开发的过程中, 我们会发现, 程序的代码有时会很"杂乱", 如果后面的项目更大了, 那就会更加地杂乱无章(文件乱, 代码内容乱). 也基于此, 接下来让我们来学习一下应用分层. 也类似于公司的组织架构 公司初创阶段, 一个人身兼数职, 既做财务, 又做人事,还有…

交易的成功并非仅依赖于拥有强大的工具,而在于如何用好你的工具

任何领域伟大的成就往往源于个人不屈不挠地克服重重障碍的能力&#xff0c;这种毅力和决心并非普通人所具备&#xff0c;因此他们往往只能停留在普通和平凡的层面。 而对于那些渴望在交易领域取得卓越成就的人来说&#xff0c;坚持采用一套经过验证且有效的交易系统&#xff0c…

11 html 学习/作业

<!DOCTYPE html> <html><head><meta charset"utf-8"><title></title></head><body><a href"./index.html">首页</a><a href"https://www.baidu.com/">百度</a><a h…

使用Windows的“远程桌面连接”Ubuntu主机连接不上问题解决

问题描述&#xff1a; 使用Windows自带的“远程桌面连接”来连接自己的Ubuntu的系统的过程中&#xff0c;自己已经成功安装了 xrdp 文件包&#xff0c;但是在使用“远程桌面连接”时&#xff0c;自己的“远程桌面连接”软件在输入Ubuntu系统的用户名和密码后&#xff0c;连接不…

Python爬虫实战—探索某网站电影排名

文章目录 Python爬虫实战—探索某网站电影排名准备工作编写爬虫代码代码解析运行情况截图进一步优化和说明完整代码总结 说明&#xff1a;本案例以XXX网站为例&#xff0c;已隐去具体网站名称与地址。 Python爬虫实战—探索某网站电影排名 网络爬虫是一种自动化程序&#xff0…

txt、pdf等文件转为一行一行的doccano数据集输入格式

文章目录 doccano 数据集导入简介代码实现代码运行结果代码公开 doccano 数据集导入 在Doccano 导入数据集时&#xff0c;使用TextLine的文件格式&#xff0c;导入的文件需要为一行一行文本的数据格式&#xff0c;每一行文本在导入Doccano后就是一条数据。 简介 主要工作说明…

LeetCode-热题100:17.电话号码的字母组合

题目描述 给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例 1&#xff1a; 输入&#xff1a; digits “23” 输出&a…

运用YOLOv5实时监测并预警行人社交距离违规情况

YOLO&#xff08;You Only Look Once&#xff09;作为一种先进的实时物体检测算法&#xff0c;在全球范围内因其高效的实时性能和较高的检测精度受到广泛关注。近年来&#xff0c;随着新冠疫情对社交距离管控的重要性日益凸显&#xff0c;研究人员开始将YOLO算法应用于社交距离…

python知识点总结(七)

python知识点总结七 1、堆和栈的区别2、如何在局部修改全局的变量a、计算结果b、计算结果 3、如何修改一个enclosing变量4、关于值传递还是地址传值5、布尔类型6、逻辑运算7、字符串切片操作8、取整、取余、除数9、变量赋值10、字符串与数字相乘11、整型、浮点型、字符型之间相…

List系列集合:ArrayList、LinkedList --java学习笔记

List系列集合 特点&#xff1a;有序、可重复、有索引 ArrayList&#xff1a;有序、可重复、有索引LinkedList&#xff1a;有序、可重复、有索引 List集合的特有方法 List集合因为支持索引&#xff0c;所以多了很多与索引相关的方法&#xff0c;当然&#xff0c;Collection的…

什么是UI设计?适合做UI设计的软件有哪些?

人们常说 UI 和 UI 设计&#xff0c;但到底什么是 UI 设计&#xff1f;UI 设计的原则是什么&#xff1f;实际上 “UI" 也就是 User Interface&#xff0c;它是用户界面的缩写。一般指用户操作界面&#xff0c;即软件程序、网站或设备的图形部分&#xff0c;用户与之互动。…