4,ThinkPHP中,Action是控制器,Model是模型,視圖是以模板方式體現的。
首先,說控制器,我只做增加和獲取列表的方法介紹。
其次,說模型,這裡才是成功的主要原因。為什麼?ThinkPHP是有字段映射的,這個在對MYSQL的支持非常完美,基本不用寫MODEL,但是對ORALCE就不行了,當使用M->add()來添加數據時,字段會被$this->_facade()方法過濾掉。這樣生成的SQL語句就是沒法執行的,肯定是錯誤的,導致數據添加不到數據庫中,那麼使用select()方法也是一樣被過濾。
再次,當我單步調試時,斷點被過濾的時候,過濾方法使用到了new出來的MODEL,這個MODEL會有一個字段映射的數組在裡面,這個過濾方法就是和這個字段數組進行對比,如果不一致就過濾掉,結果我調試發現,new出來的MODEL根本沒有把字段映射加進去,數組直接為空,當然就沒法和添加的數據字段一一對應了。這就是錯誤的關鍵。
下面就來說解決方法,其實很簡單,按照基本的MVC結構,不管是PHP還是JAVA還是.NET都有這樣的結構,那麼按照嚴格的標准,MODEL層的代碼是必須寫的,就是要和數據庫的字段做映射。但是很多用mysql的,就直接沒有去寫MODEL裡面的代碼。這種習慣被用到了oracle中,就出了問題。
5,下面針對我上面的數據表寫出我的代碼:
我的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('用戶添加錯誤');
}
} else {
header("Content-Type:text/html; charset=utf-8");
exit($M_User->getError() . ' [ <a href="javascript:history.back()">返 回</a> ]');
}
}
Action解釋:
復制代碼 代碼如下:
$M_User=new UserModel();
這個方法最好這麼寫,因為做.NET的原因,一直都這麼寫的。針對具體的模型進行實例化,嚴格規定我就要對User表進行操作了。
獲取POST數據的代碼就不多解釋了。
復制代碼 代碼如下:
$M_User->create();
這是ThinkPHP的一個方法,很好,可以幫你過濾掉非法的東西,建議使用。
復制代碼 代碼如下:
$Query_Result = $M_User->add($data);
這一段就是數據的添加,我習慣指定要添加的數據,也是因為這一段需要根據$M_User實例化,並過濾字段。當然了,我們只要做好MODEL的代碼,就不會有問題。下面的代碼就不解釋。官方文檔都有。
我的Model是這樣的:UserModel.class.php
復制代碼 代碼如下:
?protected $fields = array(
'id', 'username', 'password'
);
Model解釋:這才是重點,這有這樣,new出來的$M_User的映射字段數組才不會為空,這樣才能和POST的數據進行對應,才會讓過濾方法正常識別,不被過濾。
6,經過了以上的操作,針對Oracle的數據庫操作就完成了,我現在也可以任意使用ThinkPHP提供的方法來操作數據了,包括分頁(limit),find(),findAll等等。
連接mysql或許沒有問題,但是在oracle中,封裝的方法無法調用時,一定要在model層中加入字段的定義。