## 查找并更新
在取出數據后,更改字段內容后更新數據。
```
$user = UserModel::get(1);
$user->user_nickname = '老貓';
$user->user_email = 'genmaowan@163.com';
$user->save();
```
## 直接更新數據
也可以直接帶更新條件來更新數據
```
$user = new UserModel;
// save方法第二個參數為更新條件
$user->save([
'user_nickname' => '老貓',
'user_email' => 'genmaowan@163.com'
], ['id' => 1]);
```
上面兩種方式更新數據,如果需要過濾非數據表字段的數據,可以使用:
```
$user = new UserModel();
// 過濾post數組中的非數據表字段數據
$user->allowField(true)->save($_POST,['id' => 1]);
```
如果你通過外部提交賦值給模型,并且希望指定某些字段寫入,可以使用:
```
$user = new UserModel();
// post數組中只有user_nickname和user_email字段會寫入
$user->allowField(['user_nickname','user_email'])->save($_POST, ['id' => 1]);
```
批量更新數據
可以使用saveAll方法批量更新數據,例如:
```
$user = new UserModel;
$users = [
['id' => 1, 'user_nickname' => '老貓', 'user_email' => 'genmaowan@163.com'],
['id' => 2, 'user_nickname' => '老貓666', 'user_email' => 'genmaowan666@163.com']
];
$user->saveAll($users);
```
## 通過數據庫類更新數據
必要的時候,你也可以使用數據庫對象來直接更新數據,但這樣就無法使用模型的事件功能。
```
$user = new UserModel;
$user->where('id', 1)
->update(['user_nickname' => '老貓666']);
```
或者使用:
```
$user = new UserModel;
$user->update(['id' => 1, 'user_nickname' => '老貓666']);
```
如果傳入update的數據包含主鍵的話,可以無需使用where方法。
靜態方法
模型支持靜態方法直接更新數據,例如:
```
UserModel::where('id', 1)
->update(['user_nickname' => '老貓666']);
```
或者使用:
```
UserModel::update(['id' => 1, 'user_nickname' => '老貓666']);
```
閉包更新
可以通過閉包函數使用更復雜的更新條件,例如:
```
$user = new UserModel;
$user->save(['user_nickname' => '老貓666'],function($query){
// 更新status值為1 并且id大于10的數據
$query->where('status', 1)->where('id', '>', 10);
});
```
## 自動識別
我們已經看到,模型的新增和更新方法都是save方法,系統有一套默認的規則來識別當前的數據需要更新還是新增。
實例化模型后調用save方法表示新增;
查詢數據后調用save方法表示更新;
調用模型的save方法后表示更新;
如果你的數據操作比較復雜,可以顯式的指定當前調用save方法是新增操作還是更新操作。
顯式更新數據:
```
// 實例化模型
$user = new UserModel;
// 顯式指定更新數據操作
$user->isUpdate(true)
->save(['id' => 1, 'user_nickname' => '老貓666']);
```
顯示新增數據:
```
$user = UserModel::get(1);
$user->user_nickname = '老貓666';
// 顯式指定當前操作為新增操作
$user->isUpdate(false)->save();
```
> 注意不要在一個模型實例里面做多次更新,會導致部分重復數據不再更新,正確的方式應該是先查詢后更新或者使用模型類的update方法更新。
如果你調用save方法進行多次數據寫入的時候,需要注意,第二次save方法的時候必須使用isUpdate(false),否則會視為更新數據。
- 序言
- 基礎
- 主要特性
- 安裝ThinkCMF
- 為了更爽
- 目錄結構
- 入口文件
- 第三方庫
- 開發規范
- 數據庫規范
- 調試模式
- URL訪問
- 應用
- 配置
- 路由
- 控制器
- 控制器定義
- 控制器模板賦值
- 控制器模板渲染
- 前臺控制器
- 前臺用戶控制器
- 后臺控制器
- 跳轉,AJAX返回和重定向
- URL生成
- 請求
- 請求信息
- 輸入變量
- 請求類型
- 獲取請求頭信息
- 偽靜態
- 更多
- 系統函數
- cmf_auth_check 用戶權限檢查
- cmf_check_user_action 用戶訪問控制
- cmf_check_verification_code 數字驗證碼檢查
- cmf_clear_verification_code 清除數字驗證碼
- cmf_compare_password 用戶密碼比較
- cmf_current_lang 判斷當前語言包
- cmf_get_admin_style 獲取后臺風格
- cmf_get_content_images 獲取HTML圖片
- cmf_get_current_admin_id 登錄管理員ID
- cmf_get_current_user 獲取登錄用戶信息
- cmf_get_current_user_id 登錄用戶ID
- cmf_get_file_download_url 獲取文件下載鏈接
- cmf_get_file_extension 獲取文件擴展名
- cmf_get_image_url 獲取圖片 URL
- cmf_get_option 獲取系統配置
- cmf_get_plugin_class 獲取插件類名
- cmf_get_root 網站根目錄
- cmf_get_site_info 獲取網站信息
- cmf_get_user_avatar_url 獲取用戶頭像URL
- cmf_get_verification_code 生成數字驗證碼
- cmf_is_mobile 判斷是否為手機
- cmf_is_user_login 判斷用戶是否登錄
- cmf_is_wechat 判斷是否為微信
- cmf_password 密碼加密
- cmf_plugin_url 插件URL生成
- cmf_replace_content_file_url 替換編輯器文件地址
- cmf_send_email 發送郵件
- cmf_set_dynamic_config 設置動態配置
- cmf_set_option 設置系統配置
- cmf_split_sql 切分SQL文件
- cmf_update_current_user 更新當前用戶信息
- cmf_url_encode 生成base64的url
- cmf_verification_code_log 驗證碼發送日志
- get_client_ip 獲取客戶端IP地址
- hook 添加鉤子
- cmf_check_mobile 檢查手機號
- cmf_is_android 判斷是否為安卓手機
- cmf_is_ios 判斷是否為ios訪問
- cmf_is_iphone 判斷是否為iphone訪問
- cmf_is_ipad 判斷是否為ipad訪問
- 數據庫
- 數據庫配置
- 添加數據
- 更新數據
- 查詢數據
- 刪除數據
- 事務操作
- 更多數據庫操作
- 模型
- 模型定義
- 添加數據
- 更新數據
- 查詢數據
- 刪除數據
- 數據驗證
- 應用
- 應用的概念
- 應用開發流程
- 導航共享
- 幾個重要基類
- 后臺菜單注解
- 用戶操作配置
- URL 規則配置
- 模板
- 模板常量
- 模板標簽
- 變量輸出
- 系統變量
- 請求參數
- 使用函數
- 使用默認值
- 使用運算符
- 三元運算
- 原樣輸出
- 模板注釋
- 模板目錄
- 包含文件
- 模板布局
- 模板繼承
- 網站信息
- 內置標簽
- 循環輸出標簽
- 比較標簽
- 條件判斷
- 標簽嵌套
- 原生PHP
- 定義標簽
- CMF標簽
- 導航標簽
- 子導航標簽
- 驗證碼標簽
- 幻燈片標簽
- 鉤子標簽
- 友情鏈接標簽
- 分頁標簽
- 傻瓜式模板
- 什么是傻瓜式模板
- 模板描述文件
- 模板文件配置
- 模板變量類型
- 模板變量數據源
- 導航模板數據源
- 導航菜單模板數據源
- 幻燈片模板數據源
- 模板切換
- 插件
- 插件鉤子
- 前臺模板鉤子
- 核心鉤子
- send_mobile_verification_code
- comment
- guestbook
- admin_dashboard
- switch_theme
- admin_login
- admin_init
- home_init
- 插件類主文件
- 插件開發流程
- 插件配置
- 插件控制器
- 插件后臺管理控制器
- 插件后臺菜單
- 插件視圖
- 插件數據庫模型
- 插件多語言
- 插件API控制器
- 前端
- Wind.js
- 前端組件
- js-ajax-form
- js-ajax-delete
- js-ajax-dialog-btn
- js-count-btn
- js-date
- js-datetime
- js-bootstrap-date
- js-bootstrap-datetime
- 專題
- 緩存
- Session
- Cookie
- 分頁
- 驗證碼
- 文件上傳
- 第三方擴展
- 門戶應用
- 模板目錄結構
- 模板開發
- 模板標簽
- 加載標簽庫
- 文章列表標簽
- 面包屑標簽
- 文章分類標簽
- 所有子分類標簽
- 子分類標簽
- 標簽文章列表標簽
- 門戶模板數據源
- 文章分類模板數據源
- 頁面模板數據源
- 附錄
- 升級日志
- 升級指導