tp5.0配置达梦数据库(干货)

文章详细描述了如何在ThinkPHP项目中创建Dm数据库驱动,包括在thinkphp/library/think/db/connector目录下建立Dm.php文件,以及在thinkphp/library/think/db/builder目录下创建对应的Dm.php文件。这两个类文件主要用于处理Dm数据库的连接、数据表字段信息获取和SQL构建等操作。同时,文章还展示了数据库的配置示例。

1、在 项目/thinkphp/library/think/db/connector下,新建Dm.php

<?php

namespace think\db\connector;

use PDO;
use think\db\Connection;

/**
 * Dm数据库驱动
 */
class Dm extends Connection
{
    protected $builder = '\\think\\db\\builder\\Dm';

    /**
     * 解析pdo连接的dsn信息
     * @access protected
     * @param array $config 连接信息
     * @return string
     */
    protected function parseDsn($config)
    {
        $dsn = 'dm:';
        if (!empty($config['hostname'])) {
            $dsn .=  $config['hostname'] . ($config['hostport'] ? ':' . $config['hostport'] : '') . '/';
        }
        if (!empty($config['charset'])) {
            $dsn .= ';charset=' . $config['charset'];
        }

        return $dsn;
    }

    /**
     * 取得数据表的字段信息
     * @access public
     * @param string $tableName
     * @return array
     */
    public function getFields($tableName)
    {
        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);
        $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($dbName = '')
    {
        $sql    = 'select table_name from all_tables';
        $pdo    = $this->query($sql, [], false, true);
        $result = $pdo->fetchAll(PDO::FETCH_ASSOC);
        $info   = [];

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

        return $info;
    }

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

    protected function supportSavepoint()
    {
        return true;
    }
}

2、在 项目/thinkphp/library/think/db/builder下,新建Dm.php

<?php

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($limit)
    {
        $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($lock = false)
    {
        if (!$lock) {
            return '';
        }

        return ' FOR UPDATE NOWAIT ';
    }


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

        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()
    {
        return 'DBMS_RANDOM.value';
    }

}

3、数据库配置:

return [
    // 数据库类型
    'type'            => 'dm',
    // 服务器地址
    'hostname'        => '127.0.0.1',
    // 数据库名
    'database'        => 'SYSDBA',
    // 用户名
    'username'        => 'SYSDBA',
    // 密码
    'password'        => 'xxxxxx',
    // 端口
    'hostport'        => '5236',
    // 连接dsn
    'dsn'             => '',
    // 数据库连接参数
    // 'params'          => [],
    'params'=>array(
      \PDO::ATTR_PERSISTENT   => true,
      \PDO::ATTR_CASE         => \PDO::CASE_LOWER,
    ),
    // 数据库编码默认采用 utf8
    'charset'         => 'utf8',
    // 数据库表前缀
    'prefix'          => '',
    // 数据库调试模式
    'debug'           => false,
    // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
    'deploy'          => 0,
    // 数据库读写是否分离 主从式有效
    'rw_separate'     => false,
    // 读写分离后 主服务器数量
    'master_num'      => 1,
    // 指定从服务器序号
    'slave_no'        => '',
    // 是否严格检查字段是否存在
    'fields_strict'   => true,
    // 数据集返回类型
    'resultset_type'  => 'array',
    // 自动写入时间戳字段
    'auto_timestamp'  => false,
    // 时间字段取出后的默认时间格式,默认为Y-m-d H:i:s
    'datetime_format' => false,
    // 是否需要进行SQL性能分析
    'sql_explain'     => false,
     // Builder类
     'builder'         => '',
     // Query类
     'query'           => '\\think\\db\\Query',
      // 断线标识字符串
    'break_match_str' => [],

];

内容概要:本文档详细介绍了达梦数据库DM8与PHP-PDO扩展的集成方法,涵盖从环境搭建、驱动编译、配置详解到实际应用案例的全过程。首先,文档解析了DM8的系统架构和技术特性,重点介绍了其支持的两种存储引擎(堆表和聚簇表),并阐述了PDO_DM驱动的工作原理及其与DM8的通信机制。接着,文档详细描述了PHP环境的配置要求,包括操作系统、DM8数据库PHP版本及Visual C++ Redist的要求,以及驱动文件的获取与验证步骤。此外,还深入探讨了PDO连接配置、高级连接选项(如SSL配置)、连接状态监测与故障转移等技术细节。文档进一步讲解了PDO核心操作,包括CRUD操作、达梦特有功能(如序列、分区表、全文索引)的集成,以及高级数据类型(如BLOB/CLOB、JSON、空间数据)的处理方法。在事务管理和并发控制方面,文档介绍了事务的基础操作、隔离级别设置、锁机制与并发控制,以及分布式事务处理。性能优化部分涵盖了SQL优化、批量操作优化、存储过程与函数调用等内容。最后,文档通过实际应用案例展示了企业级应用架构设计、高并发处理方案(如读写分离、缓存集成)、数据迁移与同步的方法,以及故障诊断与性能调优的具体实践。 适用人群:具备一定PHP编程基础,熟悉数据库操作,尤其是希望将PHP应用与达梦数据库DM8集成的研发人员和技术团队。 使用场景及目标:①了解达梦数据库DM8的技术架构及其与PHP-PDO扩展的集成方法;②掌握PHP环境配置、驱动编译与验证的步骤;③实现高效稳定的PHP-PDO连接配置,包括SSL加密、连接池优化等;④掌握CRUD操作、高级数据类型处理及达梦特有功能的集成;⑤理解和应用事务管理、并发控制及分布式事务处理;⑥优化SQL查询性能,提升批量操作效率,调用存储过程与函数;⑦设计高并发处理方案,实施数据迁移与同步;⑧进行故障诊断与性能调优,确保系统的稳定性和高效性。 其他说明:本文档不仅提供了详细的理论知识和技术背景,还包含大量实用的操作步骤和代码示例,帮助读者快速上手并解决实际问题。文档内容详尽,适合从初学者到有一定经验的技术人员参考使用。
### ThinkPHP3 连接配置达梦数据库 对于ThinkPHP3框架连接达梦数据库的情况,虽然提供的参考资料主要集中在ThinkPHP 5.1版本上[^1],但是可以借鉴这些资源来构建适用于ThinkPHP3的解决方案。 #### 配置环境需求 为了使ThinkPHP3能够成功连接到达梦数据库,确保满足如下条件: - PHP 版本应至少为7.1,尽管这是针对较新版本的要求,在可能的情况下升级PHP有助于兼容性和安全性。 - 已经安装并正确配置达梦数据库(DM8),并且可以通过命令行或其他工具正常访问该数据库实例。 - 安装好适合当前PHP版本的DM PHP驱动程序。这通常涉及到下载对应的扩展文件,并按照官方指导将其集成至现有的PHP环境中[^4]。 #### 修改`config.php` 在ThinkPHP3中,数据库设置位于应用目录下的`Conf/config.php`文件内。编辑此文件加入或调整关于达梦数据库的相关参数: ```php return array( 'DB_TYPE' => 'dm', // 数据库类型改为 dm 表示达梦数据库 'DB_HOST' => 'localhost', 'DB_NAME' => 'your_database_name', 'DB_USER' => 'username', 'DB_PWD' => 'password', 'DB_PORT' => '端口号,默认可能是5236', ); ``` 请注意上述配置项中的具体值需替换为实际使用的数据库名称、用户名、密码以及端口等信息。 #### 测试连接 完成上述更改后,建议创建一个新的控制器动作来进行简单的查询测试,验证是否能顺利读取来自达梦数据库的数据记录。如果遇到任何错误提示,则应回顾之前的每一步骤确认无误后再尝试解决潜在的问题。 由于缺乏直接面向ThinkPHP3与达梦数据库对接的具体案例描述,以上指南综合考虑了现有资料和技术背景进行了合理推测和改编[^5]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值