thinkphp5支持oracle吗

发布时间 - 2019-09-12 00:00:00    点击率:

首先,我们知道php是完全支持oracle的,那么作为php框架的thinkphp5也是完全可以支持oracle的。

thinkphp5如何连接oracle?

数据库:ray

表的结构:ray_user

CREATE TABLE IF NOT EXISTS ray_user (
user_id int(11) unsigned NOT NULL AUTO_INCREMENT,
user_name varchar(10) NOT NULL,
user_pwd varchar(40) NOT NULL,
PRIMARY KEY (user_id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=18 ;

转存表中的数据:ray_user

INSERT INTO ray_user (user_id, user_name, user_pwd) VALUES
(1, ‘updatename’, ‘ray’),
(2, ‘testname’, ‘testpwd’),

1、mysql环境下的CURD操作

数据库配置database.php


// +----------------------------------------------------------------------

return [
   // 数据库类型
   'type'            => 'mysql',
   // 服务器地址
   'hostname'        => '127.0.0.1',
   // 数据库名
   'database'        => 'ray',
   // 用户名
   'username'        => 'root',
   // 密码
   'password'        => '', // 你的密码
   // 端口
   'hostport'        => '3306',
   // 连接dsn
   'dsn'             => '',
   // 数据库连接参数
   'params'          => [],
   // 数据库编码默认采用utf8
   'charset'         => 'utf8',
   // 数据库表前缀
   'prefix'          => 'ray_',
   // 数据库调试模式
   '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,
];

控制器User.php

operateUser("find",null,"1");
    var_dump($data);
    // 更新
    $updateData = [
        'user_name' => 'updatename'
    ];
    $result = $obj_user->operateUser("update",$updateData,"1");
    var_dump($result);
    // 新增
    $insertData = [
        'user_name' => 'testname',
        'user_pwd' => 'testpwd'
    ];
    $result = $obj_user->operateUser("insert",$insertData);
    var_dump($result);
    // 删除
    $result = $obj_user->operateUser("delete",null,'2');
    var_dump($result);
}
}

模型User.php

find();
    } else if($directive == "insert" && $data != null) {
        return User::save($data) ? 1 : 0;
    } else if($directive == "update" && $data != null && $user_id != null) {
        return User::where('user_id',$user_id)->find()->save($data) ? 1 : 0;
    } else if($directive == "delete" && $user_id != null) {
        return User::where('user_id',$user_id)->delete() ? 1 : 0;
    } else {
        return null;
    }
}
}

2、oracle环境下的CURD操作

数据库配置文件database.php


// +----------------------------------------------------------------------

return [
   // 数据库类型
   'type'            => '\think\oracle\Connection',
   // 服务器地址
   'hostname'        => '127.0.0.1',
   // 数据库名
   'database'        => 'orcl',
   // 用户名
   'username'        => 'Scott',
   // 密码
   'password'        => '', // 你的密码
   // 端口
   'hostport'        => '1521',
   // 连接dsn
   'dsn'             => '',
   // 数据库连接参数
   'params'          => [],
   // 数据库编码默认采用utf8
   'charset'         => 'utf8',
   // 数据库表前缀
   'prefix'          => 'ray_',
   // 数据库调试模式
   '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,
];

3、根据指定ID查询记录

由于Oracle表名和字段名均需加上双引号,故改写thinkphp\library\db\Builder.php中的parseSqlTable和parseWhereItem方法。改写完成后根据ID查询记录OK。

   ...
/**
    * 将SQL语句中的__TABLE_NAME__字符串替换成带前缀的表名(小写)
    * @access protected
    * @param string $sql sql语句
    * @return string
    */
   protected function parseSqlTable($sql)
   {
        return '"'. strtoupper($this->query->parseSqlTable($sql)).'"'; //// 前后加上双引号并将表明设置为大写
   }

......
     // where子单元分析
   protected function parseWhereItem($field, $val, $rule = '', $options = [], $binds = [], $bindName = null)
   {
       // 字段分析
       $key = $field ? '"'. $this->parseKey($field, $options, true) .'"' : ''; ////前后加上双引号

       // 查询规则和条件
       if (!is_array($val)) {
           $val = is_null($val) ? ['null', ''] : ['=', $val];
       }
       list($exp, $value) = $val;
       ...

改写了控制器和模型层方法:

控制器Users.php

operateUser("find",null,"1");
        var_dump($data);
        // 更新
        $updateData = [
            'NAME' => "updateora",
            'PWD' => "newpwd"
        ];
        $result = $obj_users->operateUser("update",$updateData,"1");
        var_dump($result);
        // 插入
        $insertData = [
            'NAME' => 'testname',
            'PWD' => 'testpwd'
        ];
        $result = $obj_users->operateUser("insert",$insertData);
        var_dump($result);
        // 删除
        $result = $obj_users->operateUser("delete",null,'18');
        var_dump($result);
    }
}

模型Users.php

find();
        } else if($directive == "insert" && $data != null) {
            /*$id = Users::getLastInsID('SEQUSERS')-2;
            var_dump($id);
            $data['ID'] = $id;*/
            return Users::save($data,[],'SEQUSERS') ? 1 : 0; // 注意这里传参
        } else if($directive == "update" && $data != null && $ID != null) {
            return Users::where('ID',$ID)->find()->save($data) ? 1 : 0;
        } else if($directive == "delete" && $ID != null) {
            return Users::where('ID',$ID)->delete() ? 1 : 0;
        } else {
            return null;
        }
    }
}

经测试更新数据通过,接下来是最为头疼的新增。因为MySQL主键自增通过给PK添加A-I属性即可,而Oracle则需要通过触发器来实现。下面采用了简单的实现方法。

触发器,序列实现Oracle主键自增。

CREATE OR REPLACE TRIGGER TRIUSERS BEFORE
INSERT ON SCOTT.USERS FOR EACH ROW
WHEN (
new.id is null
      )
begin
select SEQUSERS.nextval into:new.id from dual;
end;

create sequence SEQUSERS
minvalue 1
maxvalue 999999999999999999999999999
start with 1
increment by 1
nocache;

需要改写think-oracle\src\Connection.php里面的getLastInsId()方法

/**
     * 获取最近插入的ID
     * @access public
     * @param string  $sequence     自增序列名
     * @return string
     */
    public function getLastInsID($sequence = null)
    {
        $pdo    = $this->linkID->query("select {$sequence}.nextval as id from dual");
        $pdo    = $this->linkID->query("select {$sequence}.currval as id from dual");
        $result = $pdo->fetchColumn();
        $pdo    = $this->linkID->query("alter sequence {$sequence} increment by -1");
        $pdo    = $this->linkID->query("select {$sequence}.nextval as id from dual");
        $pdo    = $this->linkID->query("alter sequence {$sequence} increment by 1");
        return $result;
    }

以上内容仅供参考!

推荐教程:thinkphp教程


# oracle  # php  # mysql  # thinkphp  # database  # 数据库  # 双引号  # 是否存在  # 主键  # 集中式  # 采用了  # 并将  # 写了  # 设置为  # 来实现  # 配置文件 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在 React 中条件性地遍历数组并渲染元素  北京网站制作的公司有哪些,北京白云观官方网站?  php 三元运算符实例详细介绍  Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives  Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  MySQL查询结果复制到新表的方法(更新、插入)  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  高性价比服务器租赁——企业级配置与24小时运维服务  Laravel如何配置和使用缓存?(Redis代码示例)  如何基于云服务器快速搭建网站及云盘系统?  JS碰撞运动实现方法详解  Android利用动画实现背景逐渐变暗  如何在云主机快速搭建网站站点?  如何解决hover在ie6中的兼容性问题  HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】  微信小程序 配置文件详细介绍  网站建设整体流程解析,建站其实很容易!  利用 Google AI 进行 YouTube 视频 SEO 描述优化  如何在云主机上快速搭建网站?  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  如何在万网主机上快速搭建网站?  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  如何在阿里云虚拟主机上快速搭建个人网站?  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  如何在服务器上配置二级域名建站?  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  高端建站如何打造兼具美学与转化的品牌官网?  如何自定义建站之星模板颜色并下载新样式?  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  敲碗10年!Mac系列传将迎来「触控与联网」双革新  Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  Python高阶函数应用_函数作为参数说明【指导】  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  高防服务器租用指南:配置选择与快速部署攻略  图册素材网站设计制作软件,图册的导出方式有几种?