国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

PHP開發框架Laravel數據庫操作方法總結

2024-05-04 23:25:32
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了PHP開發框架Laravel數據庫操作方法總結,包含Select查詢、Insert語句、update語句、Delete語句、事務等,需要的朋友可以參考下
 
 

一、讀/寫連接

有時您可能希望使用一個SELECT語句的數據庫連接,,另一個用于插入、更新和刪除語句。Laravel使這微風,將始終使用正確的連接是否使用原始查詢,查詢生成器或雄辯的ORM。

如何讀/寫連接應該配置,讓我們看看這個例子:

復制代碼代碼如下:

'mysql' => array('read' => array('host' => '192.168.1.1'),'write' => array('host' => '196.168.1.2'),'driver' => 'mysql','database' =>'database','username' => 'root','password' => '','charset' => 'utf8','collation' => 'utf8_unicode_ci','prefix' => '')

 

注意,兩個鍵添加到配置陣列:讀和寫。這兩個鍵有數組值包含一個關鍵:主機。其余的讀寫數據庫選項從主mysql連接將合并后的數組。所以,我們只需要將物品放入讀取和寫入數組如果我們希望覆蓋主要數組中的值。所以,在這種情況下,192.168.1.1將被用作“讀”連接,while192.168.1.2將被用作“寫”連接。數據庫憑證、前綴、字符集和所有其他選項在主mysql數組將跨兩個共享連接。

二、運行查詢

一旦你已經配置了數據庫連接,你可以使用DB運行查詢類。

運行一個Select查詢

 

復制代碼代碼如下:

$results = DB::select('select * from users where id = ?', array(1));

結果的選擇方法總是返回一個數組。

 

運行一個Insert語句

 

復制代碼代碼如下:

  DB::insert('insert into users (id, name) values (?, ?)', array(1, 'Dayle'));

 

運行一個更新語句

 

復制代碼代碼如下:

  DB::update('update users set votes = 100 where name = ?', array('John'));

運行一個Delete語句

 

 

復制代碼代碼如下:

DB::delete('delete from users');

 

注意:update和delete語句返回的行數的影響操作。

運行一個通用聲明

 

復制代碼代碼如下:

DB::statement('drop table users');

 

查詢事件監聽

你可以查詢事件監聽使用DB::聽方法:

 

復制代碼代碼如下:

DB::listen(function($sql, $bindings, $time){ //});

 

三、數據庫事務

  運行在一個數據庫事務的一組操作,您可以使用事務方法:

復制代碼代碼如下:

 DB::transaction(function(){ DB::table('users')->update(array('votes' 
=> 1)); DB::table('posts')->delete();});

注意:在事務拋出的任何異常關閉將導致自動事務將回滾

 

有時你可能需要開始一個事務:

 

復制代碼代碼如下:

DB::beginTransaction();

你可以通過回滾事務回滾方法:

 

 

復制代碼代碼如下:

DB::rollback();

最后,您可以通過提交方法:提交一個事務

 

 

復制代碼代碼如下:

DB::commit();

 

四、訪問連接

當使用多個連接,你可以訪問它們通過DB::連接方法:

 

復制代碼代碼如下:

$users = DB::connection('foo')->select(...);

你也可以訪問原始的、潛在的PDO實例:
復制代碼代碼如下:

$pdo = DB::connection()->getPdo();

有時你可能需要重新連接到一個給定的數據庫:
復制代碼代碼如下:

DB::reconnect('foo');

如果你需要斷開從給定的數據庫將超過底層PDO實例'smax_connections限制,使用斷開連接方法:
復制代碼代碼如下:

DB::disconnect('foo');

 

五、查詢日志

默認情況下,Laravel日志保存在內存的所有查詢運行當前的請求。然而,在某些情況下,例如當插入的行數,這可能會導致應用程序使用多余的內存。禁用日志,你可以使用disableQueryLog方法:

 

復制代碼代碼如下:

DB::connection()->disableQueryLog();

o得到一組執行的查詢,您可以使用getQueryLog方法:
復制代碼代碼如下:

$queries = DB::getQueryLog();
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 内乡县| 金寨县| 久治县| 嘉峪关市| 许昌市| 安图县| 策勒县| 淮阳县| 印江| 镇沅| 启东市| 大丰市| 迁安市| 黔西| 波密县| 尉氏县| 莆田市| 南岸区| 井冈山市| 包头市| 崇州市| 逊克县| 尼玛县| 海阳市| 塔城市| 屏东县| 漳平市| 昌宁县| 波密县| 浑源县| 丹巴县| 琼结县| 墨脱县| 济阳县| 扎鲁特旗| 鲜城| 建阳市| 青岛市| 佛冈县| 涿州市| 家居|