快一年多没碰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>
后面就可以自己连接数据库输出数据了;