ThinkPHP6(PHP)链接达梦数据库配置

ThinkPHP6(PHP)不能直接通过现有的扩展和代码直接连接达梦数据库,要通过先在PHP中安装达梦的PDO驱动(扩展)和DM驱动(扩展),要在安装达梦的时候勾选驱动(如果有也可以不进行勾选)。

ThinkPHP6(PHP)链接达梦数据库配置

达梦数据库安装完成后,在安装目录中的php_pdo中有对应PHP版本的驱动

ThinkPHP6(PHP)链接达梦数据库配置

找到对应自己PHP版本的文件复制到PHP扩展目录中,添加948、949行的内容,注意nts和ts版本的区别,也在php.ini 中直接引用绝对地址,

ThinkPHP6(PHP)链接达梦数据库配置

添加完成后,还要将达梦的bin 目录添加的环境变量中,不然会出错

ThinkPHP6(PHP)链接达梦数据库配置

上面两步添加完成后,可执行php -m 查看,显示DM 和PDO_DM时说明安装正确,重启web服务(nginx或apache)

ThinkPHP6(PHP)链接达梦数据库配置

通过以上步骤,就可以直接使用PHP连接上达梦数据库了,可以进行相应的数据库的操作了。

ThinkPHP不能直接连接达梦,需要添加连接驱动代码,添加两个文件

1、在vendor/topthink/think-orm/src/db/builder 下添加 Dm.php

<?php
declare (strict_types = 1);

namespace think\db\builder;

use think\db\Builder;
use think\db\Query;

/**
 * Dm数据库驱动
 */
class Dm extends Builder
{
    protected $selectSql = 'SELECT * FROM (SELECT thinkphp.*, rownum AS numrow FROM (SELECT  %DISTINCT% %FIELD% FROM %TABLE%%JOIN%%WHERE%%GROUP%%HAVING%%ORDER%) thinkphp ) %LIMIT%%COMMENT%';

    /**
     * limit分析
     * @access protected
     * @param  Query $query 查询对象
     * @param  mixed $limit
     * @return string
     */
    protected function parseLimit(Query $query, string $limit): string
    {
        $limitStr = '';

        if (!empty($limit)) {
            $limit = explode(',', $limit);

            if (count($limit) > 1) {
                $limitStr = "(numrow>" . $limit[0] . ") AND (numrow<=" . ($limit[0] + $limit[1]) . ")";
            } else {
                $limitStr = "(numrow>0 AND numrow<=" . $limit[0] . ")";
            }

        }

        return $limitStr ? ' WHERE ' . $limitStr : '';
    }

    /**
     * 设置锁机制
     * @access protected
     * @param  Query      $query 查询对象
     * @param  bool|false $lock
     * @return string
     */
    protected function parseLock(Query $query, $lock = false): string
    {
        if (!$lock) {
            return '';
        }

        return ' FOR UPDATE NOWAIT ';
    }

    /**
     * 字段和表名处理
     * @access public
     * @param  Query  $query  查询对象
     * @param  string $key
     * @param  string $strict
     * @return string
     */
    public function parseKey(Query $query, $key, bool $strict = false): string
    {
        $key = trim($key);

        if (strpos($key, '->') && false === strpos($key, '(')) {
            // JSON字段支持
            list($field, $name) = explode($key, '->');
            $key                = $field . '."' . $name . '"';
        }

        return $key;
    }

    /**
     * 随机排序
     * @access protected
     * @param  Query $query 查询对象
     * @return string
     */
    protected function parseRand(Query $query): string
    {
        return 'DBMS_RANDOM.value';
    }
}

2、vendor/topthink/think-orm/src/db/connector 新建 Dm.php,达梦默认表名及字段名都是大写,如果我们的系统是其它数据库转过来的,原来都是小写,要在查询数据后将字段名转为小写,下面文件的select和find 方法,具体要根据实际情况进行设置。

<?php

namespace think\db\connector;

use PDO;
use think\db\BaseQuery;
use think\db\Connection;
use think\db\PDOConnection;
use think\db\ConnectionInterface;
use think\db\Query;

/**
 * Dm数据库驱动
 */
// class Dm extends Connection
class Dm extends PDOConnection
{
    /**
     * 解析pdo连接的dsn信息
     * @access protected
     * @param array $config 连接信息
     * @return string
     */
    protected function parseDsn(array $config): string
    {
        // $dsn = 'dm:host=';
        // if (!empty($config['hostname'])) {
        //     //  dm Instant Client
        //     $dsn .=  $config['hostname'] . ($config['hostport'] ? ':' . $config['hostport'] : '') . '/';
        //     // $dsn .=  $config['hostname'];
        // }


        // if (!empty($config['charset'])) {
        //     $dsn .= ';charset=' . $config['charset'];
        // }

        // return $dsn;
        $dsn = "dm:host=".$config['hostname'];
        return $dsn;
    }

    /**
     * 取得数据表的字段信息
     * @access public
     * @param string $tableName
     * @return array
     */
    public function getFields(string $tableName): array
    {
        list($tableName) = explode(' ', $tableName);
        $sql             = "select a.column_name,data_type,DECODE (nullable, 'Y', 0, 1) notnull,data_default, DECODE (A .column_name,b.column_name,1,0) pk from all_tab_columns a,(select column_name from all_constraints c, all_cons_columns col where c.constraint_name = col.constraint_name and c.constraint_type = 'P' and c.table_name = '" . strtoupper($tableName) . "' ) b where table_name = '" . strtoupper($tableName) . "' and a.column_name = b.column_name (+)";

        // $pdo    = $this->query($sql, [], false, true);
        // $result = $pdo->fetchAll(PDO::FETCH_ASSOC);
        $pdo    = $this->getPDOStatement($sql);
        $result = $pdo->fetchAll(PDO::FETCH_ASSOC);

        $info   = [];

        if ($result) {
            foreach ($result as $key => $val) {
                $val                       = array_change_key_case($val);
                $info[$val['column_name']] = [
                    'name'    => $val['column_name'],
                    'type'    => $val['data_type'],
                    'notnull' => $val['notnull'],
                    'default' => $val['data_default'],
                    'primary' => $val['pk'],
                    'autoinc' => $val['pk'],
                ];
            }
        }
        return $this->fieldCase($info);
    }

    /**
     * 取得数据库的表信息(暂时实现取得用户表信息)
     * @access   public
     * @param string $dbName
     * @return array
     */
    public function getTables(string $dbName = ''): array
    {
        $sql    = 'select table_name from all_tables';
        // $pdo    = $this->query($sql, [], false, true);
        // $result = $pdo->fetchAll(PDO::FETCH_ASSOC);
        $pdo    = $this->getPDOStatement($sql);
        $result = $pdo->fetchAll(PDO::FETCH_ASSOC);
        $info   = [];

        foreach ($result as $key => $val) {
            $info[$key] = current($val);
        }

        return $info;
    }

    /**
     * 获取最近插入的ID(如果使用自增列,需去掉此方法)
     * @access public
     * @param BaseQuery $query    查询对象
     * @param string    $sequence 自增序列名
     * @return mixed
     */
    // public function getLastInsID($sequence = null)
   /* public function getLastInsID(BaseQuery $query, string $sequence = null)
    {
        $pdo      = $this->linkID->query("select {$sequence}.currval as id from dual");
        $insertId = $pdo->fetchColumn();

        return $this->autoInsIDType($query, $insertId);
    }*/

    /**
     * SQL性能分析
     * @access protected
     * @param string $sql
     * @return array
     */
    protected function getExplain(string $sql)
    {
        return [];
    }

    protected function supportSavepoint(): bool
    {
        return true;
    }

    /*
     * 查询数据 字段大写转小写
     */
    public function select(BaseQuery $query): array
    {
        $resultSet= parent::select($query);
        foreach($resultSet as &$item){
            $item=array_change_key_case($item , CASE_LOWER);
        }
        return $resultSet;
    }

    /*
     * 查询数据 字段大写转小写
     */
    public function find(BaseQuery $query): array
    {
        $resultSet= parent::find($query);
        return array_change_key_case($resultSet , CASE_LOWER);
    }
}

然后修改数据库配置文件或env文件,TYPE 要设置为Dm,其它根据实际情况设置

ThinkPHP6(PHP)链接达梦数据库配置

两个Dm.php 文件来源于网上,又改了一点点

如果遇到显示乱码,可以在 c:/windows/system32下建一个dm_svc.conf 文件 里面添加

CHAR_CODE=(PG_UTF8)

ThinkPHP6(PHP)链接达梦数据库配置

配置文件

[DATABASE]
TYPE = Dm
HOSTNAME = 192.168.1.111:5236
USERNAME = SYSDBA
PASSWORD = SYSDBA
DEBUG = true
PREFIX = database_name.pre_

原创文章,作者:admin,如若转载,请注明出处:https://ntib.cn/292.html

(3)
adminadmin
上一篇 2023年11月19日 下午9:20
下一篇 2023年11月19日 下午11:59

相关推荐

  • ThinkPHP模型事件

    企业建设电子商务网站的目的模型事件是指在进行模型的写入操作的时候触发的操作行为,包括模型的save方法和delete方法。 模型事件包括下面几种,分为新增前后、更新前后、写入前后、和删除前后,暂时称4个分组…

    记事本 2023年11月18日
  • 阿里云composer镜像

    企业建设电子商务网站的目的阿里云composer镜像与 Packagist 官方实时同步,推荐使用最新的 Composer 版本。所有项目都会使用该镜像地址: 取消配置还原到默认的地址:

    记事本 2023年11月18日
  • 网站分步引导组件Driver.js

    企业建设电子商务网站的目的在web使用中经常看到分步引导功能,提示你如何操作及功能演示,有很多工具可以实现这种功能。如Driver.js、introjs等, Driver.js 使用MIT Licensed…

    2023年11月18日
  • PHP导出xls,xlsx表格

    企业建设电子商务网站的目的在老旧的项目中使用PHPExcel 导出表格,数据量大一点的时候,服务器就扛不住了,如果您不想使用PhpSpreadsheet进行导出,可以尝试使用 PHP_XLSXWriter,…

    2024年12月31日
  • mysql 将一个表中的数据更新到另一个表中

    企业建设电子商务网站的目的update table_a ,table_bset table_a.field = table_b.fieldwhere table_a.id= table_b.aid 将 ta…

    记事本 2023年11月18日
  • PHP安装OCI8扩展访问 Oracle 数据库

    企业建设电子商务网站的目的1、安装oracle客户端 检查是否安装成功,安装成功时显示下图 2、修改 /etc/ld.so.conf,添加下方代码 3、添加软连接 4、添加环境变量 /etc/profile…

    2024年6月5日
  • Google浏览器离线版下载方法

    企业建设电子商务网站的目的打开地址: https://www.google.cn/chrome/?standalone=1&platform=win64 ,再点击 在此下载时就可以下载到 chrom…

    2024年3月16日
  • FreeSWITCH 突然不能拨打电话问题

    企业建设电子商务网站的目的公司呼叫系统,在正常使用中突然大面积出现呼叫失败,马上登录服务器查看呼叫日志,出现下图所示的 (NATIVE SQL ERR [database or disk is full])…

    2018年11月18日
  • PHP版本VC6与VC9/VC11/VC14、Thread Safe与None-Thread Safe等的区别

    企业建设电子商务网站的目的在安装 PHP 时,下载时有各种选项,VC9,VC11,VC14 的,那这些都是什么呢 包名里的VC6、VC9、VC11、VC14、VC15,代表的是编写时使用的编译器。 你需要在…

    记事本 2018年11月18日
  • Mac虚拟机Parallels Desktop

    企业建设电子商务网站的目的Parallels Desktop 18(PD18)是一种在Mac上同时运行macOS和Windows的虚拟机,支持Intel和M芯片,并在Mac和Windows之间无缝复制和粘贴…

    2024年3月16日

发表回复

登录后才能评论

评论列表(9条)

  • 1282
    1282 2023年11月20日 下午8:28

    大佬问一下
    我配置完后也确保拓展都开启了,怎么还是会报{“code”:10501,”msg”:”could not find driver”,”file”:”C:\\software\\SE\\PHP\\phpstudy_pro\\WWW\\dm\\vendor\\topthink\\think-orm\\src\\db\\PDOConnection.php”,”line”:”797″}

    • admin
      admin 2023年11月20日 下午9:15

      @1282看配置文件 数据库类型对不对

    • 1282
      1282 2023年11月21日 下午4:36

      @admin大哥我连上了 但是回显的数据展示 0 => array:4 [
      “id” => 1
      “name” => b”ÕÅÈý”
      “num” => “100”
      “numrow” => 1
      ] name里面的那种乱码该怎么解决,求教

    • admin
      admin 2023年11月21日 下午8:19

      @1282可以在 c:/windows/system32下建一个dm_svc.conf 文件 里面添加

      CHAR_CODE=(PG_UTF8)

    • 1282
      1282 2023年11月23日 上午9:14

      @admin感谢感谢,弄好了(就是DB类好像用不了,只能写原生的大哭

    • admin
      admin 2023年11月23日 下午5:11

      @1282我试是可以的

  • 1282
    1282 2023年12月6日 下午10:11

    大佬我问一下,thinkphp6.0 怎么配置 才能访问远程的达梦数据库,我试了一下,好像不能访问

    • admin
      admin 2023年12月7日 下午3:23

      @1282使用远程地址就行了,看远程数据库是否允许进行连接

  • admin
    admin 2024年6月6日 下午2:28

    Linux 添加环境变量/etc/profile export LD_LIBRARY_PATH=***/dmdbms/bin

WeChat