1. 程式人生 > >THINKPHP 資料操作方法

THINKPHP 資料操作方法

一·ThinkPHP Insert 新增資料

ThinkPHP 內建的 add 方法用於向資料表新增資料,相當於 SQL 中的 INSERT INTO 行為。

新增資料 add 方法是 CURD(Create,Update,Read,Delete / 建立,修改,讀取,刪除)中的 Create 的實現,ThinkPHP 支援以普通陣列方式和麵向物件方式將資料寫入資料表。

現在以《PHP MySQL 資料庫教程》中操作 user 表資料的例子(具體參見:MySQL Insert into 新增資料)為例,來演示如何在 ThinkPHP 中實現對資料表的資料新增操作。

例子:

在 IndexAction 控制器(Lib/Action/IndexAction.class.php)裡,新增 insert() 操作:

public function insert()

{

header("Content-Type:text/html; charset=utf-8");

 $Dao = M("User"); // 例項化模型類 // 構建寫入的資料陣列

 $data["username"] = "小王";

 $data["password"] = md5("123456");

$data["regdate"] = time(); // 寫入資料

if($lastInsId = $Dao->add($data))

{

echo "插入資料 id 為:$lastInsId";

 }

else {

 $this->error('資料寫入錯誤!');

} }

訪問執行該操作:http://127.0.0.1/html/Myapp/index.php/Index/insert

語法解讀

  1. M("User") 用於高效例項化一個數據模型(M 是 new Model 的簡寫,稱為快捷方法),引數為要操作的表名。
  2. 接下來構建要儲存資料的陣列 $data 。
  3. 最後是用 add() 方法將資料寫入庫表,由於使用的是 M快捷方法,需要將 $data 陣列傳入 add() 方法。
  4. add() 方法如果新增資料記錄成功,返回的是新資料記錄主鍵,可直接得到。

該例子實際執行的 SQL 為:

INSERT INTO user

(username,password,email,regdate)

 VALUES

 ('小王','e10adc3949ba59abbe56e057f20f883e','[email protected]',1283612673)

提示:執行該例子,請確認在配置檔案里正確配置了資料庫的相關賬號密碼等資訊,具體參見《ThinkPHP 專案配置

物件方式新增資料

上面的方式是以構造資料陣列的方式,然後將資料以引數形式傳入 add 方法寫入資料表。ThinkPHP 也支援以物件的方式將資料寫入資料表,將上面的程式碼更改為:

public function insert()

{

header("Content-Type:text/html; charset=utf-8");

 $Dao = M("User"); // 例項化模型類 // 資料物件賦值

$Dao->username = "小王";

 $Dao->password = md5("123456");

 $Dao->regdate = time(); // 寫入資料

if($lastInsId = $Dao->add()){ echo "插入資料 id 為:$lastInsId";

}

 else {

$this->error('資料寫入錯誤!');

 } }

物件方式除了資料以資料物件方式賦值外,在呼叫 add 方法寫入資料的時候不需要傳遞引數。

二·ThinkPHP 更新資料 save方法

save()

ThinkPHP 中使用 save() 方法來更新資料庫,並且也支援連貫操作的使用。

例子:

public function update(){

 header("Content-Type:text/html; charset=utf-8");

$Dao = M("User"); // 需要更新的資料

// 更新的條件 $condition['username'] = 'Jack';

 $result = $Dao->where($condition)->save($data);

//或者:$resul t= $Dao->where($condition)->data($data)->save();

if($result !== false){ echo '資料更新成功!';

}

else{

echo '資料更新失敗!';

 } }

上面例子執行的 SQL 語句為:

UPDATE user SET email='[email protected]' WHERE username='Jack'

提示

為了保證資料庫的安全,避免出錯更新整個資料表,如果沒有任何更新條件,資料物件本身也不包含主鍵欄位的話,save方法不會更新任何資料庫的記錄。

因此要使用 save() 方法更新資料,必須指定更新條件或者更新的資料中包含主鍵欄位

使用主鍵的例子:

public function update(){

 header("Content-Type:text/html; charset=utf-8");

 $Dao = M("User"); // 需要更新的資料

 $data['email'] = '[email protected]'; $data['uid'] = 2;

 $result = $Dao->save($data);

if($result !== false)

{

echo '資料更新成功!';

 }else{

echo '資料更新失敗!';

 } }

如果需要更新的資料裡面包含主鍵,那麼 ThinkPHP 會自動把主鍵的值作為條件來更新。

上面的例子跟下面的效果相同:

// 需要更新的資料 $data['email'] = '[email protected]'; // 更新的條件 $condition['uid'] = 2; $result = $Dao->where($condition)->save($data);

如果是表單資料,還可以使用 create() 方法建立資料物件來更新資料:

public function update(){

header("Content-Type:text/html; charset=utf-8");

 $Dao = D("User");

 if($vo = $Dao->create())

{ $result = $Dao->save();

if($result !== false)

{ echo '資料更新成功!';

}else{

echo '資料更新失敗!';

 } }

else{

$this->error($Form->getError());

 } }

如果更新的資料需要做邏輯處理,可以在操作類以物件的方式處理或者在模型內處理,具體可參考《ThinkPHP 表單資料智慧寫入 create 方法》。

注意:以create() 方法建立資料物件來更新資料,表單中必須包含一個以主鍵為名稱的隱藏域,才能完成儲存操作。

三·ThinkPHP 查詢資料 select(findAll)方法

ThinkPHP 查詢資料主要提供以下幾類查詢:

  1. select:普通查詢,同 findAll() 方法
  2. find:取得符合查詢條件的一條記錄
  3. getBy動態查詢:根據某個欄位取得符合查詢條件的一條記錄
  4. getField:獲取某個欄位的值或多個欄位的索引陣列
  5. 區間查詢:取得符合查詢條件的區間記錄
  6. 統計查詢:取得符合查詢條件的統計資料
  7. 定位查詢:取得符合查詢條件的一條或多條記錄
  8. 原生SQL查詢:支援以原生 SQL 進行查詢或執行操作

select() 是 ThinkPHP 中最常用的普通查詢方法,得到的是一個二維陣列。findAll() 為 select() 方法的別名,並建議使用 select()。

讀取操作

下面的例子將 user 表的所有資料讀取出來並顯示:

public function read()

{

$Dao = M("User"); // 查詢資料

$list = $Dao->select();

//dump($list);

// 用 dump() 可以在除錯階段檢視資料是否已讀取

 // 模板變數賦值 $this->assign("list", $list);

// 輸出模板 $this->display();

 }

假設上面的例子對應的 class 檔案為 Lib/Action/IndexAction.class.php ,那麼對應的模板檔案為 Tpl/default/Index/read.html。

資料顯示模板

模板檔案用於顯示剛才讀取的 User 表的資料。在學習階段,要不想使用模板,也可以直接使用 foreach 語法在 read() 操作內直接顯示讀取的資料。下面是模板相應的程式碼片段,我們將讀取的資料在一個表格中顯示出來:

<table border="1">

 <tr>

<th width="10%">ID</th>

 <th width="30%">使用者名稱</th>

 <th width="30%">電子郵件</th>

<th>註冊時間</th>

 </tr>

<volist name="list" id="vo">

<tr>

<td align="center">{$vo['uid']}</td>

 <td>{$vo['username']}</td>

<td>{$vo['email']}</td>

 <td>{$vo['regdate']|date='Y-m-d H:i',###}</td>

 </tr>

</volist>

</table>

要了解更多關於 ThinkPHP模板的知識,請參閱:《ThinkPHP 模板》。

field() 查詢指定欄位

select() 方法預設是查詢所有欄位的資料,如果要查詢某個或某些欄位,就需要使用 filed() 方法。

filed() 是屬於 ThinkPHP 連貫操作中的一個方法,如在上面的例子中,只查詢使用者名稱和電子郵件地址,則查詢方法對應更改為:

$list = $Dao->field('username,email')->select();

使用查詢條件

使用 ThinkPHP 連貫操作可以很方便的對資料查詢使用查詢條件。下面是一些簡單的查詢條件的例子。

where() 條件

…… // 構造查詢條件 $condition['username'] = 'Admin'; // 查詢資料 $list = $Dao->where($condition)->select(); ……

上述查詢的就是 username='Admin' 這個條件的資料。關於 ThinkPHP where 條件更詳細資料,請參閱《ThinkPHP Where 條件》。

ORDER BY 排序

在查詢中使用 ORDER BY 對資料進行排序:

…… // 查詢資料 $list = $Dao->order('uid DESC')->select(); ……

這個例子就是資料按照 ORDER BY uid DESC 進行查詢,而 order() 方法中的引數意義跟 SQL 語句中的意義完全一致。

LIMIT 限制

在查詢中使用 LIMIT 限定資料返回的記錄數:

…… // 查詢資料 $list = $Dao->limit('4,5')->select(); ……

這個例子就是將第 5-10 條記錄取出,limit() 方法內的引數意義跟 SQL 語句中的 LIMIT 完全一致。

連貫操作

ThinkPHP 中允許將資料物件中的各個方法寫在一起操作,如:

$list = $Dao->order('uid DESC')->limit('4,5')->select();

這就是連貫操作,關於連貫操作更詳細的介紹,參見《ThinkPHP 連貫操作》。

四·ThinkPHP 刪除資料記錄 delete 方法

ThinkPHP 中使用 delete() 方法來刪除資料庫中的資料記錄,並且也支援連貫操作的使用。delete() 方法執行成功返回操作影響(刪除)的記錄數。

例子:

public function del(){

 header("Content-Type:text/html; charset=utf-8");

$Dao = M("User"); // 刪除 uid=5 的資料記錄

 $result = $Dao->where('uid = 5')->delete();

 if($result !== false){

echo '刪除 ',$result,' 條資料。';

}else{

 echo '刪除資料失敗!';

} }

上面例子執行的 SQL 為:

DELETE FROM user WHERE uid = 5

delete() 方法可以用於刪除單個或者多個數據,主要取決於 where() 刪除條件。另外也可以配合連貫操作中的其他方法如 order()、limit() 等構造出更符合需要的刪除條件:

$Dao = M("User");

$result = $Dao->where('status=0')->order('regdate ASC')->limit('5')->delete();

上面例子根據使用者註冊時間降序排列,刪除 5 條 status=0 的使用者記錄。