ThinkPHP 是一個免費開源的,快速、簡單的面向對象的 輕量級PHP開發框架 ,創立於2006年初,遵循Apache2開源協議發布,是為了敏捷WEB應用開發和簡化企業應用開發而誕生的。ThinkPHP從誕生以來一直秉承簡潔 實用的設計原則,在保持出色的性能和至簡的代碼的同時,也注重易用性。並且擁有眾多的原創功能和特性,在社區團隊的積極參與下,在易用性、擴展性和性能方 面不斷優化和改進,已經成長為國內最領先和最具影響力的WEB應用開發框架,眾多的典型案例確保可以穩定用於商業以及門戶級的開發。
ThinkPHP基於MVC的PHP框架
M – Model 模型 工作:負責數據的操作
V – View 視圖(模板) 工作:負責前台頁面顯示
C – Controller 控制器(模塊) 工作:描述功能
ThinkPHP核心文件介紹
├─ThinkPHP.php 框架入口文件
├─Common 框架公共文件
├─Conf 框架配置文件
├─Extend 框架擴展目錄
├─Lang 核心語言包目錄
├─Lib 核心類庫目錄
│ ├─Behavior 核心行為類庫
│ ├─Core 核心基類庫
│ ├─Driver 內置驅動
│ │ ├─Cache 內置緩存驅動
│ │ ├─Db 內置數據庫驅動
│ │ ├─TagLib 內置標簽驅動
│ │ └─Template 內置模板引擎驅動
│ └─Template 內置模板引擎
└─Tpl 系統模板目錄
#項目目錄結構及說明:
Home 前台應用文件夾
├─Common 項目公共文件目錄
├─Conf 項目配置目錄
├─Lang 項目語言目錄
├─Lib 項目類庫目錄
│ ├─Action Action類庫目錄
│ ├─Behavior 行為類庫目錄
│ ├─Model 模型類庫目錄
│ └─Widget Widget類庫目錄
├─Runtime 項目運行時目錄
│ ├─Cache 模板緩存目錄
│ ├─Data 數據緩存目錄
│ ├─Logs 日志文件目錄
│ └─Temp 臨時緩存目錄
└─Tpl 項目模板目錄
ThinkPHP 3 MVC模式和URL訪問
什麼是MVC
M -Model 編寫model類 對數據進行操作
V -View 編寫html文件,頁面呈現
C -Controller 編寫類文件(UserAction.class.php)
ThinkPHP的MVC特點
編寫非常靈活,只有view都可以執行
ThinkPHP的MVC對應的目錄
M 項目目錄/應用目錄/Lib/Model
V 項目目錄/應用目錄/Tpl
C 項目目錄/應用目錄/Lib/Action
url訪問C
url的4種訪問方式
1.PATHINFO 模式
http://域名/項目名/入口文件/模塊名/方法名/鍵1/值1/鍵2/值2
2.普通模式
http://域名/項目名/入口文件?m=模塊名&a=方法名&鍵1=值1&鍵2=值2
3.REWRITE模式
http://域名/項目名/模塊名/方法名/鍵1/值1/鍵2/值2
4.兼容模式
http://域名/項目名/入口文件?s=模塊名/方法名/鍵1/值1/鍵2/值2
ThinkPHP 3.1.2 輸出和模型使用
ThinkPHP 3 的輸出
a、通過 echo 等PHP原生的輸出方式在頁面中輸出
b、通過display方法輸出
想分配變量可以使用assign方法
c、修改左右定界符
休要修改配置文件中的配置項
‘TMPL_L_DELIM’=>'<{‘, //修改左定界符
‘TMPL_R_DELIM’=>’}>’, //修改右定界符
ThinkPHP 3 的模型使用
需要在方法中通過new Model(表名)的形式操作數據庫
$m=new Model(‘User’);
$arr=$m->select();
‘DB_TYPE’=>’mysql’, //設置數據庫類型
‘DB_HOST’=>’localhost’,//設置主機
‘DB_NAME’=>’thinkphp’,//設置數據庫名
‘DB_USER’=>’root’, //設置用戶名
‘DB_PWD’=>”, //設置密碼
‘DB_PORT’=>’3306′, //設置端口號
‘DB_PREFIX’=>’tp_’, //設置表前綴
也可以使用DSN方法進行配置
‘DB_DSN’=>’mysql://root:@localhost:3306/thinkphp’,//使用DSN方式配置數據庫信息
如果兩種方式同時存在,以DSN方式為優先
還有一種簡單實用模型的方式
M() 等效為 new Model();
$m=M(‘User’);
$arr=$m->select();
使用模型的實例可以對數據進行操作,操作的工作一般就是對數據庫進行 增刪改查 CURD
增 -C Create $m->add()
刪 -D Delete $m->delete()
改 -U Update $m->save()
查 -R Read $m->select()
a、模板可以遍歷數組
1
2
3
<volist name='data' id='vo'>
<{$vo.id}>----<{$vo.username}>-----<{$vo.sex}><br/>
</volist>
b、我們可以開啟調試功能中的page_trace
1.開啟調試功能
//3.開啟調試模式(在主入口文件配置index.php)
define(‘APP_DEBUG’,true);
2.我們需要設置配置文件,開啟頁面trace
‘SHOW_PAGE_TRACE’=>true,//開啟頁面Trace,需要有$this->display()才顯示
CURD特性
讀取數據
對數據的讀取 Read
$m=new Model(‘User’);
$m=M(‘User’);
select
$m->select();//獲取所有數據,以數組形式返回
find
$m->find(2);//獲取單條數據
getField(字段名)//獲取一個具體的字段值
$arr=$m->where(‘id=2′)->getField(‘username’);
創建數據
對數據的添加 Create
$m=new Model(‘User’);
$m=M(‘User’);
$m->字段名=值
$m->add();
返回值是新增的id號
刪除數據
$m=M(‘User’);
$m->delete(2); //刪除id為2的數據
$m->where(‘id=2′)->delete(); //與上面效果相同,也是刪除id為2的數據
返回值是受影響行數
更新數據
$m=M(‘User’);
$data['id']=1;
$data['username']=’ztz2′;
$m->save($data);
返回值是受影響行數
查詢方式
普通查詢方式
a、字符串
$arr=$m->where(“sex=0 and username=’gege'”)->find();
b、數組
$data['sex']=0;
$data['username']=’gege';
$arr=$m->where($data)->find();
注意:這種方式默認是and的關系,如果使用or關系,需要添加數組值
$data['sex']=0;
$data['username']=’gege';
$data['_logic']=’or';
表達式查詢方式
$data['id']=array(‘lt’,6);
$arr=$m->where($data)->select();
EQ 等於
NEQ不等於
GT 大於
EGT大於等於
LT 小於
ELT小於等於
LIKE 模糊查詢
$data['username']=array(‘like’,’%ge’);
$arr=$m->where($data)->select();
NOTLIKE
$data['username']=array(‘notlike’,’%ge%’); //notlike中間沒有空格
$arr=$m->where($data)->select();
注意:如果一個字段要匹配多個通配符
$data['username']=array(‘like’,array(‘%ge%’,’%2%’,’%五%’),’and’);//如果沒有第三個值,默認關系是or關系
$arr=$m->where($data)->select();
BETWEEN
$data['id']=array(‘between’,array(5,7));
$arr=$m->where($data)->select();
//SELECT * FROM tp_user WHERE ( (id BETWEEN 5 AND 7 ) )
$data['id']=array(‘not between’,array(5,7));//注意,not 和 between中間一定要有空格
$arr=$m->where($data)->select();
IN
$data['id']=array(‘in’,array(4,6,7));
$arr=$m->where($data)->select();
//SELECT * FROM tp_user WHERE ( id IN (4,6,7) )
$data['id']=array(‘not in’,array(4,6,7));
$arr=$m->where($data)->select();
//SELECT * FROM tp_user WHERE ( id NOT IN (4,6,7) )
區間查詢
$data['id']=array(array(‘gt’,4)