URL和路由
靈石網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)公司,靈石網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為靈石數(shù)千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的靈石做網(wǎng)站的公司定做!
5.0的URL訪問不再支持普通URL模式,路由也不支持正則路由定義,而是全部改為規(guī)則路由配合變量規(guī)則(正則定義)的方式:
主要改進如下:
1.增加路由變量規(guī)則;
增加組合變量支持;
增加資源路由;
增加路由分組;
增加閉包定義支持;
增加MISS路由定義;
支持URL路由規(guī)則反解析;
2.請求對象和響應(yīng)對象
5.0新增了請求對象Request和響應(yīng)對象Response,Request統(tǒng)一處理請求和獲取請求信息,Response對象負責(zé)輸出客戶端或者瀏覽器響應(yīng)。
3.廢除原來的操作前后置方法;
增加beforeActionList屬性定義前置操作;
支持任意層次的控制器定義和訪問;
URL訪問支持自動定位控制器;
4.數(shù)據(jù)庫
5.0的數(shù)據(jù)庫查詢功能增強,原先需要通過模型才能使用的鏈?zhǔn)讲樵兛梢灾苯油ㄟ^Db類調(diào)用,原來的M函數(shù)調(diào)用可以改用db函數(shù),例如:
3.2版本
M('User')-where(['name'='thinkphp'])-find();
5.0版本
db('User')-where('name','thinkphp')-find();
5.自動驗證和自動完成
5.0的數(shù)據(jù)自動驗證和自動完成和3.2版本區(qū)別較大,5.0的數(shù)據(jù)驗證采用驗證器定義并且通過think\Validate類進行統(tǒng)一的驗證。自動完成則通過在模型里面定義修改器來完成。
6.異常
5.0對錯誤零容忍,默認情況下會對任何級別的錯誤拋出異常(但可以在應(yīng)用公共文件中設(shè)置錯誤級別),并且重新設(shè)計了異常頁面,展示了詳盡的錯誤信息,便于調(diào)試.
如果要用thinkphp查詢出一張表的所有數(shù)據(jù),可以這樣來做: 假設(shè)數(shù)據(jù)表的表名為:think_table1,這里think_ 是表前綴(包含下滑線)。 thinkphp內(nèi)置了M函數(shù),可以這樣實例化think_table1這張表: M('table1') , 因為think_這個前綴名稱在配置文...
5.0版本和之前版本的差異較大,本篇對熟悉3.2版本的用戶給出了一些5.0的主要區(qū)別。
URL和路由
5.0的URL訪問不再支持普通URL模式,路由也不支持正則路由定義,而是全部改為規(guī)則路由配合變量規(guī)則(正則定義)的方式:
主要改進如下;
增加路由變量規(guī)則;
增加組合變量支持;
增加資源路由;
增加路由分組;
增加閉包定義支持;
增加MISS路由定義;
支持URL路由規(guī)則反解析;
請求對象和響應(yīng)對象
5.0新增了請求對象Request和響應(yīng)對象Response,Request統(tǒng)一處理請求和獲取請求信息,Response對象負責(zé)輸出客戶端或者瀏覽器響應(yīng)。
模塊和控制器
控制器的命名空間有所調(diào)整,并且可以無需繼承任何的控制器類。
應(yīng)用命名空間統(tǒng)一為app(可定義)而不是模塊名;
控制器的類名默認不帶Controller后綴,可以配置開啟use_controller_suffix參數(shù)啟用控制器類后綴;
控制器操作方法采用return方式返回數(shù)據(jù)?而非直接輸出;
廢除原來的操作前后置方法;
增加beforeActionList屬性定義前置操作;
支持任意層次的控制器定義和訪問;
URL訪問支持自動定位控制器;
數(shù)據(jù)庫
5.0的數(shù)據(jù)庫查詢功能增強,原先需要通過模型才能使用的鏈?zhǔn)讲樵兛梢灾苯油ㄟ^Db類調(diào)用,原來的M函數(shù)調(diào)用可以改用db函數(shù),例如:
3.2版本
M('User')-where(['name'='thinkphp'])-find();
5.0版本
db('User')-where('name','thinkphp')-find();
主要改進如下:
支持鏈?zhǔn)讲樵儾僮鳎?/p>
數(shù)據(jù)查詢支持返回對象、數(shù)組和PDOStatement對象;
數(shù)據(jù)集查詢支持返回數(shù)組和Collection對象;
增加查詢構(gòu)造器,查詢語法改變;
支持閉包查詢;
支持分塊查詢;
支持視圖查詢;
增加SQL監(jiān)聽事件;
模型
5.0的模型變化是最大的,基本上模型是完全面向?qū)ο蟮母拍?,包括關(guān)聯(lián)模型,模型類的后綴不再帶Model,直接由命名空間區(qū)分,原來的D函數(shù)調(diào)用改為model函數(shù),并且必須創(chuàng)建對應(yīng)的模型類,例如:
3.2版本
D('User')-where(['name'='thinkphp'])-find();
5.0版本
model('User')-where('name','thinkphp')-find();
主要改進包括:
重構(gòu)關(guān)聯(lián)模型;
支持聚合模型;
廢除視圖模型(改為數(shù)據(jù)庫的視圖查詢方法);
模型的擴展采用Trait機制;
增加獲取器和修改器;
增加時間戳自動寫入;
增加類型字段轉(zhuǎn)換;
數(shù)組訪問支持;
JSON序列化支持;
自動驗證和自動完成
5.0的數(shù)據(jù)自動驗證和自動完成和3.2版本區(qū)別較大,5.0的數(shù)據(jù)驗證采用驗證器定義并且通過think\Validate類進行統(tǒng)一的驗證。自動完成則通過在模型里面定義修改器來完成。
異常
5.0對錯誤零容忍,默認情況下會對任何級別的錯誤拋出異常(但可以在應(yīng)用公共文件中設(shè)置錯誤級別),并且重新設(shè)計了異常頁面,展示了詳盡的錯誤信息,便于調(diào)試。
調(diào)試和日志
5.0的頁面Trace強化,支持瀏覽器控制臺查看Trace信息。
5.0的日志驅(qū)動增加Socket方式,采用SocketLog支持遠程調(diào)試。
常量
5.0版本廢棄了原來的大部分常量定義,僅僅保留了框架的路徑常量定義,其余的常量可以使用App類或者Request類的相關(guān)屬性或者方法來完成,或者自己重新定義需要的常量。
廢除的常量包括:
REQUEST_METHOD?IS_GET?IS_POST?IS_PUT?IS_DELETE?IS_AJAX?__EXT__?COMMON_MODULE?MODULE_NAME?CONTROLLER_NAME?ACTION_NAME?APP_NAMESPACE?APP_DEBUG?MODULE_PATH
函數(shù)
5.0版本核心框架不依賴任何自定義函數(shù),但仍然封裝了一些常用功能到助手函數(shù),你可以隨意重新定義或者增加助手函數(shù)。
提示 dbs.user表不存在
看看是數(shù)據(jù)庫名錯了還是表名錯了或多加了表前綴
原生SQL查詢有 query() 和 execute() 兩個方法:
query():用于 SQL 查詢操作,并返回符合查詢條件的數(shù)據(jù)集
execute():更新和寫入數(shù)據(jù)的 SQL 操作,返回影響的記錄數(shù)
query()
query() 方法是用于 SQL 查詢操作,和select()方法一樣返回符合查詢條件的數(shù)據(jù)集。
例子:
public function read(){
// 實例化一個空模型,沒有對應(yīng)任何數(shù)據(jù)表
$Dao = M();
//或者使用 $Dao = new Model();
$list = $Dao-query("select * from user where uid5");
if($list){
$this-assign('list', $list );
$this-display();
} else {
$this-error($Dao-getError());
}
}
對于 query() 方法返回的數(shù)據(jù)集,跟 select() 一樣,可以在模板里直接循環(huán)輸出。
execute()
execute() 方法用于更新和寫入數(shù)據(jù)的 SQL 操作(注:非查詢操作,無返回數(shù)據(jù)集),返回影響的記錄數(shù)。
例子:
public function read(){
header("Content-Type:text/html; charset=utf-8");
// 實例化一個空模型,沒有對應(yīng)任何數(shù)據(jù)表
$Dao = M();
//或者使用 $Dao = new Model();
$num = $Dao-execute("update user set email = '12345@xxx.com' where uid=3");
if($num){
echo '更新 ',$num,' 條記錄。';
}else{
echo '無記錄更新';
}
}
如果查詢比較復(fù)雜或一些特殊的數(shù)據(jù)操作不能通過 ThinkPHP 內(nèi)置的 ORM 和 ActiveRecord 模式實現(xiàn)時,就可以通過直接使用原生 SQL 查詢來實現(xiàn)。
注意:以上都是 user 沒有表前綴的例子,在查詢語句中,查詢的表應(yīng)該寫實際的表名字(包括前綴)。
Thinkphp可以使用數(shù)據(jù)庫表前綴的。
在database.php文件中設(shè)置prefix屬性即可。
(以上截圖來源于Thinkphp官方文檔)
設(shè)置了前綴以后。使用方法舉例如下:
假設(shè)設(shè)置的前綴是think_,我們要連接的數(shù)據(jù)表是name。
1、數(shù)據(jù)庫方式:
D('name')-select();?//查詢think_name數(shù)據(jù)表的全部數(shù)據(jù)。
2、模型方式:
model('name')-select();?//默認情況下,查詢think_name數(shù)據(jù)表的全部數(shù)據(jù)。
模型還有其他實例化或者靜態(tài)調(diào)用的方式,你可以直接查看官方文檔。