程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> Thinkphp中Create方法深入探究

Thinkphp中Create方法深入探究

編輯:關於PHP編程

由於工作原因在thinkPHP的create()方法上遇到了問題,所以跟蹤了create(),從而進一步探究了create()方法。
原來create()方法原來有兩個參數第一個參數就是眾所周知的數據參數第二個是隱藏的$type參數,那麼這個參數用來控制什麼的呢?
// 狀態$type = $type?$type!empty($data[$this->getPk()])?self::MODEL_UPDATE:self::MODEL_INSERT);
仔細琢磨了這句話才發現,這個隱藏參數是用來指明本次數據庫具體是什麼操作的,1即為插入操作,0即為更新操作
默認的情況下是不用給這個參數賦值的,原因是,系統能自動識別

它是這麼識別的:

如果您傳入的數據中有與主鍵相同字段的,則本次數據庫操作則默認為更新操作,這麼判斷主要是因為大部分情況主鍵都是默認自增的,插入操作一般不會給主鍵賦值,但問題就出在這裡


最近做的項目直接把學號作為主鍵,而學號不能使用自增而是有固定格式的,必須錄入,
但是系統就自動把我的錄入操作當成了更新操作,而我的自動完成代碼都是這麼寫的:
復制代碼 代碼如下:protected $_auto = array(
        array('majorid','maxmajoridadd1',1,'callback'),
    );

第三個參數1查看手冊就知道是指這個自動完成操作是在插入時候執行的。
而系統把我的插入操作當成了更新操作,我設置的自動完成代碼自然就失效而不被執行了

當出現了你也要錄入主鍵字段值的情況的時候您可以這麼寫

復制代碼 代碼如下:create($_POST,1)

直接告訴create方法此次操作是插入操作

這是非常難以發現的問題,最近發現好多人遇到此問題,特此撰文說明。

此外自動驗證/自動完成功能失效還有可能是你的Model類名稱寫錯了之類的,我就犯過這種錯誤,多個字母少個字母經常的事情

基本上自動驗證/自動完成失效就這兩種情況

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved