[TOC]
## 【字段刪除·思路分析】
> 涉及兩個數據表(models_field和test)
1、刪除models_field表中記錄
2、刪除副表中相應字段
重難點:通用的函數table_exists
模型主要負責數據處理,返回整型值
控制器主要負責業務員邏輯判斷,通常用switch……case……default判斷
## 【SQL修改某字段值】
~~~
UPDATE tp_models_field SET issystem = 0 WHERE modelid=31;
~~~
## 【整合公共函數·顯示所有數據表】
> 整合前代碼:
~~~
public function list_tables(){
$tables = array();
$data = Db::query('SHOW TABLES');
foreach ($data as $value) {
$tables[] = $value['Tables_in_' . config('database.database')];
}
return $tables;
}
~~~
> 整合后代碼:【整合公共函數·顯示所有數據表】
~~~
公共函數代碼:application應用目錄下面common.php
/**
* [table_exists 檢測數據表是否存在]
* @param string $tablename [表名,不含前綴]
* @return [bool] [存在返回true,不存在返回false]
*/
function table_exists($tablename='')
{
//獲取所有數據表名
$tables = [];
$data = Db::query('SHOW TABLES');
foreach ($data as $value) {
$tables[] = $value['Tables_in_'.config('database.database')];
}
//獲取表前綴
$dbPrefix = config('database.prefix');
//當前的表名
$tablename=$dbPrefix.$tablename;
if(in_array($tablename,$tables)){
return true; //存在
}else {
return false; //不存在
}
}
~~~
## 【完整代碼】
> 控制器代碼:
~~~
/**
* [delete 刪除字段]
* @param integer $id [字段ID]
* @return [type] [提示信息]
*/
public function delete($id=0, $modelid=0){
if(0 == $id){
return error('該字段不存在');
}
//實例化字段模型
$modelsfield = new ModelsFieldModel;
$resultId = $modelsfield->deleteField($id);//返回狀態碼
switch ($resultId) {
case -1:
return error('該字段不存在!');
break;
case -2:
return error('數據表不存在!');
break;
case -3:
return error('該字段不允許被刪除!');
break;
default:
return success('字段刪除成功',url('index',array('id'=>$modelid,'tab'=>1)));
break;
}
}
~~~
> 模型代碼:
~~~
/**
* [deleteField 刪除字段,需刪除models_field表中記錄以及副表相應字段]
* @param [int] $fieldid [字段ID]
* @return [int] [狀態碼]
*/
public function deleteField($fieldid){
$info = Db::name('models_field')->where('id',$fieldid)->find();
if(empty($info)){
return -1; //該字段不存在
exit;
}
//判斷副表是否存在
$modelid = $info['modelid'];
$modelname = Db::name('models')->where('id',$modelid)->value('tablename');
if(!table_exists($modelname)){
return -2; //副表不存在
exit;
}
//判斷是否允許刪除
if(1 == $info['issystem']){
return -3; //該字段不允許被刪除
exit;
}else{
//刪除models_field表中記錄
Db::name('models_field')->where('id',$fieldid)->delete();
//刪除副表中相應字段
$dbPrefix = config('database.prefix');
Db::execute("ALTER TABLE `{$dbPrefix}{$modelname}` DROP COLUMN `{$info['field']}` ;");
}
}
~~~
> 【sublime text安裝自動補全注釋的插件】
https://blog.csdn.net/baidu_38300480/article/details/79379795
https://www.cnblogs.com/qingkong/p/5039527.html
https://www.cnblogs.com/feifei-cyj/p/7718793.html
1、重啟sublime text 3,快捷鍵Ctrl + Shift + P ,在輸入框中出入pack..找到Install Package。
2、點擊Install Package,在輸入框中,安裝DocBlockr插件。
3、安裝成功之后,Preferences->Package Settings->DocBlockr->Settings-User,在文件中添加以下代碼并保存:
{
"jsdocs_extra_tags":["@author lucky","@DateTime {{datetime}}"]
}
- Layer無刷新不跳轉彈框提示信息
- 整合ThinkPHP+實用代碼
- TP整合Layer插件實現無刷新
- 自定義助手函數
- 添加信息失敗后不跳轉
- 三種無限級分類
- TP常用代碼
- 自定義公共函數
- TP模型管理專題
- TP模型管理之添加模型
- sfox_newmodel.sql
- TP模型管理之刪除模型
- TP模型管理之編輯模型
- TP模型管理之字段添加
- sfox_newmodel.sql_edit
- layer_hplus.js_edit
- TP模型管理之字段刪除
- TP模型管理之字段編輯
- TP模型管理之預覽模型
- TP模型管理之公共函數
- layer_hplus.js_修訂一
- TP模型管理之預覽模型靜態頁
- 后臺內容管理系統
- 分類樹顯示
- 內容列表顯示
- 信息發布
- 編輯信息
- layer_hplus.js
- myJs第一版
- myJs第二版
- myJs第三版
- myJs第四版
- TP5插件用法
- Datatables
- WebUploader
- bootstrap-fileinput
- UEditor
- 簡單調用
- 路徑問題
- 跨域多圖上傳
- 跨域單圖上傳
- UEditor圖片跨域上傳解決方案
- 定制工具欄圖標
- ajaxFileUpload
- LayUI
- 圖片上傳
- layui分頁
- 搜索頁
- 搜索優化及刪除
- Uploadify
- TP5前端應用
- 靜態首頁
- 前臺首頁功能實現
- 自定義標簽庫
- 前臺模板繼承應用
- 首頁自定義標簽改進
- 文章內容頁
- 自定義標簽改進
- 自定義標簽修正
- 圖片等比例自動縮放
- 后臺權限管理
- 角色管理
- 規則管理
- 權限設置
- 會員管理
- 權限管理
- 前臺登錄注冊功能
- 注冊登錄
- 阿里大于手機注冊
- 阿里大于升級阿里云短信服務
- 自動登錄完成
- PHP異位或加密實現自動登陸
- 微信開發
- 分享接口
- 靜態頁面實現微信分享
- 動態頁微信分享
- 頁面靜態化
- 1-全站靜態化前期配置
- 2-鏈接地址靜態化
- TP5常用片段代碼
- 加載靜態資源路徑與常量
- thinkphp5預定義常量
- 刪除某文件夾的內容
- 解壓插件包
- 異步提交插件
- 其他功能
- 背景音樂
- 手機訪問PC網站自動跳轉到手機網站代碼
- 手機微信音樂MP3播放器
- 后盾之網頁背景音樂
- 播放器寬度自適應
- 前臺首頁數據調用
- 視頻列表
- 搜索分頁
- H5解決蘋果(IOS)不能自動播放音樂
- 清空緩存
- 文件處理常識
- 刪除路徑下的所有文件夾和文件
- 一鍵清空緩存
- 評論留言
- 格式化時間
- 替換微博內容的URL地址@用戶與表情
- PHP正則理解
- jQuery評論插件
- TP空操作
- TP路由
- 跨域訪問
- 設置請其頭允許跨域請求
- 模板前臺判斷手機訪問跳轉手機網址代碼
- PHP遍歷一個文件夾下所有文件和子文件夾
- PHP獲取視頻的第一幀與時長
- TP5數據庫
- 鏈式操作原理
- update替換字段部分內容
- 后臺開發
- 后臺登錄頁居中顯示
- TP5自帶驗證碼
- JS & JQuery專題
- 二級城市聯動菜單
- 模板引擎
- 混合模板編譯
- 黃永成TP微博開發
- 消息推送
- memcache安裝
- 插件開發
- 插件介紹
- 插件鉤子
- 淺談初步理解鉤子
- 插件鉤子(hooks)分析
- 插件鉤子簡單理解
- 控制器調用插件
- 鉤子通用處理函數
- 插件基類代碼
- 插件測試代碼
- 淺談鉤子與插件
- 技術綜合
- 常用代碼
- PHP
- 56個PHP開發常用代碼片段(上)
- 56個PHP 開發常用代碼片段(中)
- 56個PHP 開發常用代碼片段(下)
- sublime text安裝自動補全注釋的插件
- 影音視頻開發
- 視頻
- H5視頻直播掃盲
- 音樂
- 語音
- PHP實現語音播報功能
- MUI
- 窗體操作