thinkphp连接oracle数据库

快一年多没碰PHP了,有可能是因为换工作的问题,现在又由于工作上的原因,想用着oracle写个东西。但一想到THINKPHP要怎么连Oracle数据库,就有点蒙蔽,以前mysql一连,用个Phpstudy就能跑起来的。现在还是先想想看怎么连数据库吧

心路历程:

本以为phpstudy跑不起来就去下了个wampserver,配置了好久,但一看phpinfo()还是没有oci的扩展。最后以为下载wampserver版本不行,卸载了一发,就抱着侥幸的心理去用了phpstudy。这一试还真行。

1.这边我们可以先确认下自己oracle版本。我这边是11g的

1.

2.开启图中的扩展php_pdo_oci.dll,php_oci_8.dll,php_oci_11g.dll。

3.查看下phpinfo().看到oracle扩展启动了

4.thinkphp5需要下载两个oracle驱动类:GitHub - top-think/think-oracle: Oracle数据库驱动。这边是下载地址,或者你也可以下载我配置好的TP5.0版本的驱动。

不设置的话,运行的时候会报这个错误

那我就按5.0设置了

(1)将Builder.php和Connection.php分别放到:\thinkphp\library\think\db对应的builder和connector目录并都改名为Oracle.php;

(2)修改builder目录下的Oracle.php文件,如下:

<span style="color:#ffffff">namespace think\oracle;

use think\db\Builder as BaseBuilder;
use think\db\Query;

/**
 * Oracle数据库驱动
 */
class Builder extends BaseBuilder
</span>

 改为

<span style="color:#ffffff">namespace think\db\builder;

use think\db\Builder;
use think\Exception;

/**
 * Oracle数据库驱动
 */
class Oracle extends Builder</span>

 (3)修改connector目录下的Oracle.php文件,如下:

<span style="color:#ffffff">namespace think\oracle;

use PDO;
use think\db\Connection as BaseConnection;

/**
 * Oracle数据库驱动
 */
class Connection extends BaseConnection
</span>

 改为

<span style="color:#ffffff">namespace think\db\connector;

use PDO;
use think\db\Connection;
use think\Log;
/**
 * Oracle数据库驱动
 */
class Oracle extends Connection</span>

 (4)配置Oracle连接参数,如下:

<span style="color:#ffffff">return [
    // 数据库类型
    'type'            => 'oracle',
    // 服务器地址
    'hostname'        => '127.0.0.1',
    // 数据库名
    'database'        => 'orcl',
    // 用户名
    'username'        => 'test',
    // 密码
    'password'        => '你的Oracle数据库密码',
    // 端口
    'hostport'        => '1521',
    // 连接dsn
    'dsn'             => '',
    // 数据库连接参数
    'params'          => [],
    // 数据库编码默认采用utf8
    'charset'         => 'utf8',
    // 数据库表前缀
    'prefix'          => '',
    // 数据库调试模式
    'debug'           => true,
    // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
    'deploy'          => 0,
    // 数据库读写是否分离 主从式有效
    'rw_separate'     => false,
    // 读写分离后 主服务器数量
    'master_num'      => 1,
    // 指定从服务器序号
    'slave_no'        => '',
    // 是否严格检查字段是否存在
    'fields_strict'   => true,
    // 数据集返回类型
    'resultset_type'  => 'array',
    // 自动写入时间戳字段
    'auto_timestamp'  => false,
    // 时间字段取出后的默认时间格式
    'datetime_format' => 'Y-m-d H:i:s',
    // 是否需要进行SQL性能分析
    'sql_explain'     => false,
];
</span>

 后面就可以自己连接数据库输出数据了;

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
连接数据库的代码可以写在ThinkPHP的配置文件(config.php)中,也可以写在具体的模块或控制器中。 1. 写在配置文件中 在config.php中,可以使用以下代码连接数据库: ```php // 数据库配置信息 return [ 'db_type' => 'mysql', 'db_host' => 'localhost', 'db_name' => 'database_name', 'db_user' => 'username', 'db_pwd' => 'password', 'db_port' => '3306', 'db_prefix'=> 'prefix_', ]; ``` 其中,db_type表示数据库类型,db_host表示数据库主机地址,db_name表示数据库名,db_user表示数据库用户名,db_pwd表示数据库密码,db_port表示数据库端口号,db_prefix表示数据表前缀。根据实际情况修改以上信息即可。 2. 写在模块或控制器中 在模块或控制器中,可以使用以下代码连接数据库: ```php $config = [ // 数据库类型 'type' => 'mysql', // 服务器地址 'hostname' => 'localhost', // 数据库名 'database' => 'database_name', // 用户名 'username' => 'username', // 密码 'password' => 'password', // 端口 'hostport' => '', // 连接dsn 'dsn' => '', // 数据库连接参数 'params' => [], // 数据库编码默认采用utf8 'charset' => 'utf8', // 数据库表前缀 'prefix' => 'prefix_', ]; // 创建一个数据库连接实例 $db = \think\Db::connect($config); ``` 其中,$config数组中的每个元素表示数据库连接相关的配置信息,根据实际情况修改以上信息即可。使用\think\Db::connect()方法创建一个数据库连接实例,然后就可以使用该实例执行数据库操作了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值