thinkphp中連接oracle時(shí)封裝方法無法用的解決辦法
其實(shí)根據(jù)以前問題我做了幾天調(diào)試,找到了問題所在,并成功在我自己一個(gè)小項(xiàng)目練習(xí)中使用正常,那么現(xiàn)在就將我的經(jīng)驗(yàn)分享給大家。
1,數(shù)據(jù)庫的連接及配置文件的內(nèi)容我就不說了, 上面已經(jīng)做了解釋。我這里只根據(jù)一個(gè)數(shù)據(jù)表的例子來說明我的操作。
2,表結(jié)構(gòu)如下:

3,這個(gè)表中有3個(gè)字段,ID主鍵,用戶名username和密碼password,因?yàn)閛racle數(shù)據(jù)庫把表名和字段都是轉(zhuǎn)成大寫的,同時(shí)不支持ID主鍵自增,我只有使用另外的方法來實(shí)現(xiàn)這個(gè)功能,比如:ID自動(dòng)序列+觸發(fā)器實(shí)現(xiàn)ID自增。
4,ThinkPHP中,Action是控制器,Model是模型,視圖是以模板方式體現(xiàn)的。
首先,說控制器,我只做增加和獲取列表的方法介紹。
其次,說模型,這里才是成功的主要原因。為什么?ThinkPHP是有字段映射的,這個(gè)在對MYSQL的支持非常完美,基本不用寫MODEL,但是對ORALCE就不行了,當(dāng)使用M->add()來添加數(shù)據(jù)時(shí),字段會(huì)被$this->_facade()方法過濾掉。這樣生成的SQL語句就是沒法執(zhí)行的,肯定是錯(cuò)誤的,導(dǎo)致數(shù)據(jù)添加不到數(shù)據(jù)庫中,那么使用select()方法也是一樣被過濾。
再次,當(dāng)我單步調(diào)試時(shí),斷點(diǎn)被過濾的時(shí)候,過濾方法使用到了new出來的MODEL,這個(gè)MODEL會(huì)有一個(gè)字段映射的數(shù)組在里面,這個(gè)過濾方法就是和這個(gè)字段數(shù)組進(jìn)行對比,如果不一致就過濾掉,結(jié)果我調(diào)試發(fā)現(xiàn),new出來的MODEL根本沒有把字段映射加進(jìn)去,數(shù)組直接為空,當(dāng)然就沒法和添加的數(shù)據(jù)字段一一對應(yīng)了。這就是錯(cuò)誤的關(guān)鍵。
下面就來說解決方法,其實(shí)很簡單,按照基本的MVC結(jié)構(gòu),不管是PHP還是JAVA還是.NET都有這樣的結(jié)構(gòu),那么按照嚴(yán)格的標(biāo)準(zhǔn),MODEL層的代碼是必須寫的,就是要和數(shù)據(jù)庫的字段做映射。但是很多用mysql的,就直接沒有去寫MODEL里面的代碼。這種習(xí)慣被用到了oracle中,就出了問題。
5,下面針對我上面的數(shù)據(jù)表寫出我的代碼:
我的Action是這樣的:UserAction.class.php??刂破魑抑粚μ砑雍筒檎易隼?,因此代碼如下:
public function index() {
header("Content-Type:text/html; charset=utf-8");
$M_User = new UserModel();
$User_List = $M_User->select();
$this->assign('Title', '用戶管理');
$this->assign('UserList', $User_List);
$this->display();
}
//添加用戶提交處理
public function Create_Post() {
$M_User = new UserModel();
$data['username'] = $this->_post('username');
$data['password'] = md5($this->_post('pwd'));
if ($M_User->create()) {
$Query_Result = $M_User->add($data);
if (false !== $Query_Result) {
$this->success('用戶添加成功');
} else {
$this->error('用戶添加錯(cuò)誤');
}
} else {
header("Content-Type:text/html; charset=utf-8");
exit($M_User->getError() . ' [ <a href="javascript:history.back()">返 回</a> ]');
}
}
Action解釋:
$M_User=new UserModel();
這個(gè)方法最好這么寫,因?yàn)樽?NET的原因,一直都這么寫的。針對具體的模型進(jìn)行實(shí)例化,嚴(yán)格規(guī)定我就要對User表進(jìn)行操作了。
獲取POST數(shù)據(jù)的代碼就不多解釋了。
$M_User->create();
這是ThinkPHP的一個(gè)方法,很好,可以幫你過濾掉非法的東西,建議使用。
$Query_Result = $M_User->add($data);
這一段就是數(shù)據(jù)的添加,我習(xí)慣指定要添加的數(shù)據(jù),也是因?yàn)檫@一段需要根據(jù)$M_User實(shí)例化,并過濾字段。當(dāng)然了,我們只要做好MODEL的代碼,就不會(huì)有問題。下面的代碼就不解釋。官方文檔都有。
我的Model是這樣的:UserModel.class.php
?protected $fields = array(
'id', 'username', 'password'
);
Model解釋:這才是重點(diǎn),這有這樣,new出來的$M_User的映射字段數(shù)組才不會(huì)為空,這樣才能和POST的數(shù)據(jù)進(jìn)行對應(yīng),才會(huì)讓過濾方法正常識(shí)別,不被過濾。
6,經(jīng)過了以上的操作,針對Oracle的數(shù)據(jù)庫操作就完成了,我現(xiàn)在也可以任意使用ThinkPHP提供的方法來操作數(shù)據(jù)了,包括分頁(limit),find(),findAll等等。
連接mysql或許沒有問題,但是在oracle中,封裝的方法無法調(diào)用時(shí),一定要在model層中加入字段的定義。
相關(guān)文章
php中g(shù)et_object_vars()在數(shù)組的實(shí)例用法
在本篇文章小編給大家整理的是一篇關(guān)于php中g(shù)et_object_vars()在數(shù)組的實(shí)例用法,對此有興趣的朋友們可以學(xué)習(xí)下。2021-02-02解析用PHP實(shí)現(xiàn)var_export的詳細(xì)介紹
本篇文章是對使用PHP實(shí)現(xiàn)var_export的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP數(shù)組去重的更快實(shí)現(xiàn)方式分析
這篇文章主要介紹了PHP數(shù)組去重的更快實(shí)現(xiàn)方式,結(jié)合實(shí)例形式對比分析了php實(shí)現(xiàn)數(shù)組去重的各種常見操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-05-05PHP簡單實(shí)現(xiàn)循環(huán)鏈表功能示例
這篇文章主要介紹了PHP簡單實(shí)現(xiàn)循環(huán)鏈表功能,簡單描述了循環(huán)鏈表的概念、功能并結(jié)合實(shí)例形式分析了php定義及使用循環(huán)鏈表的相關(guān)操作技巧,需要的朋友可以參考下2017-11-11php中json_decode()和json_encode()的使用方法
json_decode對JSON格式的字符串進(jìn)行編碼而json_encode對變量進(jìn)行 JSON 編碼,需要的朋友可以參考下2012-06-06PHP通過iconv將字符串從GBK轉(zhuǎn)換為UTF8字符集
PHP通過iconv將字符串從GBK轉(zhuǎn)換為UTF8字符集的方法,需要的朋友可以參考下。2011-07-07