Thinkphp6连接Oracle 数据库

1.配置database.php

'oracle' => [
            // 服务名
            'instance_name'  => 'xe',
           // 数据库类型
            'type'              => 'oracle',
            // 服务器地址
            'hostname'          => '192.168.3.134',
            // 数据库名
            'database'          => 'LCJZ',
            // 用户名
            'username'          => 'LCJZ',
            // 密码
            'password'          => 'a123456',
            // 端口
            'hostport'          => '1521',
            // 数据库编码默认采用utf8
            'charset'         => 'utf8',
            // 数据库表前缀
            'prefix'          => '',
        ],
  1. 修改Thinkphp6 连接配置
    在这里插入图片描述
    原来
        $dsn = 'oci:dbname=';

        if (!empty($config['hostname'])) {
            //  Oracle Instant Client
            $dsn .= '//' . $config['hostname'] . ($config['hostport'] ? ':' . $config['hostport'] : '') . '/'.$config['instance_name'];
        }

        $dsn .= $config['database'];


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

        return $dsn;

改成

        $dbstr = 'oci:dbname=';
        $dbstr .="(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST =".$config['hostname'].")(PORT = ".$config['hostport']."))(CONNECT_DATA =
        (SERVICE_NAME = ".$config['instance_name'].")))";    //SERVICE_NAME连接类型,这里是用SID的方式连接
        if (!empty($config['charset'])) {
            $dbstr .= ';charset=' . $config['charset'];
        }
        return $dbstr;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值