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 】
相关推荐:
Python面向对象测试方法_mock解析【教程】
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
如何在IIS中配置站点IP、端口及主机头?
文字头像制作网站推荐软件,醒图能自动配文字吗?
PythonWeb开发入门教程_Flask快速构建Web应用
Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
SQL查询语句优化的实用方法总结
高端建站三要素:定制模板、企业官网与响应式设计优化
如何用花生壳三步快速搭建专属网站?
今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】
laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法
Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程
INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】
简历没回改:利用AI润色让你的文字更专业
为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】
如何用JavaScript实现文本编辑器_光标和选区怎么处理
C++时间戳转换成日期时间的步骤和示例代码
Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置
微信小程序 五星评分(包括半颗星评分)实例代码
C++用Dijkstra(迪杰斯特拉)算法求最短路径
如何用PHP快速搭建高效网站?分步指南
详解阿里云nginx服务器多站点的配置
1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤
Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】
如何在橙子建站上传落地页?操作指南详解
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
如何用5美元大硬盘VPS安全高效搭建个人网站?
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
html5的keygen标签为什么废弃_替代方案说明【解答】
安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出
详解CentOS6.5 安装 MySQL5.1.71的方法
Laravel如何处理文件下载请求?(Response示例)
如何用低价快速搭建高质量网站?
Laravel如何实现一对一模型关联?(Eloquent示例)
百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
Linux后台任务运行方法_nohup与&使用技巧【技巧】
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
如何在阿里云完成域名注册与建站?
Laravel如何保护应用免受CSRF攻击?(原理和示例)
用yum安装MySQLdb模块的步骤方法
WEB开发之注册页面验证码倒计时代码的实现
如何用PHP工具快速搭建高效网站?
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
如何在不使用负向后查找的情况下匹配特定条件前的换行符
html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】
如何快速搭建个人网站并优化SEO?


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;
}
}
}